/*
Theme Name: Innvori
Theme URI: http://gitlab.magicboxdesk.com/administradores/innvori-v2
Author: MagicBoxDesk
Author URI: https://magicboxdesk.com
Description: Tema custom FSE para Innvori v2 — rebuild ultrarrápido sin Elementor. Bloques nativos + WC Blocks oficiales. Replica look del pro1 conservando funcionalidades.
Version: 0.2.0
Requires at least: 6.5
Tested up to: 6.6
Requires PHP: 8.1
License: Proprietary
Text Domain: innvori
Tags: full-site-editing, woocommerce, custom
*/

/* ============================================================
   INNVORI THEME · v0.2 (pasada 1: header + footer + hero)
   Paleta:
     --inv-primary    : #19BE6F (verde)
     --inv-secondary  : #EBF8F2 (verde muy claro)
     --inv-accent     : #FF9505 (naranja)
     --inv-text       : #062A3F (azul oscuro)
     --inv-text-soft  : #475569
     --inv-divider    : rgba(255,255,255,0.08)
   ============================================================ */

:root{
  --inv-primary:#19BE6F;
  --inv-secondary:#EBF8F2;
  --inv-accent:#FF9505;
  --inv-text:#062A3F;
  --inv-text-soft:#475569;
  --inv-bg:#ffffff;
}

/* ---------- Topbar ---------- */
.topbar{font-size:13px;}
.topbar .topbar-msg, .topbar .topbar-contact{margin:0;}
.topbar a{color:#fff;text-decoration:none;}
.topbar a:hover{text-decoration:underline;}
@media (max-width:782px){
  .topbar .topbar-contact{display:none;}
}

/* ---------- Header ---------- */
/* El template-part header viene con has-global-padding + is-layout-constrained,
   lo que mete padding lateral y limita max-width incluso en páginas page.html.
   Forzamos full-width y movemos el padding al hijo (topbar / header-main),
   para que el azul oscuro del topbar y el blanco del header se extiendan
   borde-a-borde igual que en /tienda/ (donde WooCommerce lo neutraliza). */
header.site-header.has-global-padding{
  padding-left:0 !important;
  padding-right:0 !important;
  max-width:none !important;
}
.site-header > .topbar,
.site-header > .header-main{
  max-width:none !important;
  width:100% !important;
  box-sizing:border-box;
}
.site-header > .topbar{
  padding-left:var(--wp--style--root--padding-left,24px) !important;
  padding-right:var(--wp--style--root--padding-right,24px) !important;
}
.site-header > .header-main{
  padding-left:var(--wp--style--root--padding-left,24px) !important;
  padding-right:var(--wp--style--root--padding-right,24px) !important;
}
.site-header{background:#fff;border-bottom:1px solid #eef1f4;position:sticky;top:0;z-index:50;}
.site-header .header-main{background:#fff;}
.site-header .site-logo img,
.site-header .wp-block-site-logo img{max-height:80px !important;width:auto !important;max-width:none !important;}
.site-header .wp-block-site-logo{flex:0 0 auto;}
.site-header .wp-block-navigation a{color:var(--inv-text);font-weight:600;text-decoration:none;padding:.5em .75em;}
.site-header .wp-block-navigation a:hover,
.site-header .wp-block-navigation .current-menu-item > a{color:var(--inv-primary);}

/* Search compacto en cabecera */
.header-actions{gap:14px;align-items:center;}
.header-search .wp-block-search__inside-wrapper{border:1px solid #dfe5ec;border-radius:999px;padding:2px 4px;background:#fff;}
.header-search input[type="search"]{border:none;padding:6px 10px;font-size:14px;min-width:180px;background:transparent;}
.header-search input[type="search"]:focus{outline:none;}
.header-search .wp-block-search__button{background:var(--inv-primary);color:#fff;border:none;border-radius:999px;padding:6px 10px;}
.header-search .wp-block-search__button svg{fill:#fff;}

/* Mini-cart */
.wp-block-woocommerce-mini-cart{color:var(--inv-text);}
.wc-block-mini-cart__button{color:var(--inv-text);padding:6px 8px;}
.wc-block-mini-cart__badge{background:var(--inv-accent);color:#fff;font-weight:700;}

/* Account link */
.header-account a{color:var(--inv-text);text-decoration:none;font-weight:600;font-size:14px;padding:6px 8px;}
.header-account a:hover{color:var(--inv-primary);}

/* ---------- Hero ---------- */
.hero{position:relative;}
.hero .hero-title{margin:.5rem 0 1rem;}
@media (max-width:782px){
  .hero .hero-title{font-size:36px !important;}
  .hero{min-height:380px !important;}
}

/* ---------- Strip de servicios ---------- */
.services-strip h3{margin-top:14px !important;}
.services-strip .wp-block-column{padding:18px;}

/* ============================================================
   WooCommerce product cards — grid FORZADO con selectores reales
   ============================================================ */
.wc-block-product-template,
.wp-block-woocommerce-product-template,
ul.wc-block-product-template,
ul.products,
ul.wp-block-post-template{
  display:grid !important;
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:18px !important;
  list-style:none !important;
  padding:0 !important;
  margin:0 !important;
}
@media (max-width:1280px){
  .wc-block-product-template,
  .wp-block-woocommerce-product-template,
  ul.products{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
}
@media (max-width:1024px){
  .wc-block-product-template,
  .wp-block-woocommerce-product-template,
  ul.products{grid-template-columns:repeat(3,minmax(0,1fr)) !important;}
}
@media (max-width:782px){
  .wc-block-product-template,
  .wp-block-woocommerce-product-template,
  ul.products{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width:480px){
  .wc-block-product-template,
  .wp-block-woocommerce-product-template,
  ul.products{grid-template-columns:1fr !important;}
}

/* Cada producto (selectores reales WP/WC 10.x) */
.wc-block-product-template > li,
.wc-block-product-template > .wc-block-product,
.wc-block-product-template > .wp-block-post,
.wp-block-woocommerce-product-template > li,
.wp-block-woocommerce-product-template > .wc-block-product,
.wp-block-woocommerce-product-template > .wp-block-post,
ul.products > li.product{
  width:100% !important;
  max-width:100% !important;
  flex:none !important;
  margin:0 !important;
  background:#fff !important;
  border:1px solid #eef1f4 !important;
  border-radius:8px !important;
  padding:14px !important;
  display:flex !important;
  flex-direction:column !important;
  transition:box-shadow .2s, transform .2s !important;
}
.wc-block-product-template > li:hover,
.wp-block-woocommerce-product-template > li:hover,
.wc-block-product-template > .wc-block-product:hover,
ul.products > li.product:hover{
  box-shadow:0 6px 24px rgba(6,42,63,.10) !important;
  transform:translateY(-2px) !important;
}
.wc-block-product-template img,
.wp-block-woocommerce-product-template img{
  max-width:100% !important;
  height:auto !important;
  object-fit:contain !important;
  max-height:140px !important;
  margin:0 auto;
}
.wc-block-product-template .wp-block-woocommerce-product-image,
.wp-block-woocommerce-product-template .wp-block-woocommerce-product-image{
  max-height:150px;display:flex;align-items:center;justify-content:center;overflow:hidden;
}
/* Título producto: fuente más grande y legible */
.wc-block-product-template .wp-block-post-title,
.wp-block-woocommerce-product-template .wp-block-post-title,
.wc-block-product-template .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title{
  font-size:15px !important;
  font-weight:700 !important;
  line-height:1.3 !important;
  color:var(--inv-text) !important;
  margin:10px 0 6px !important;
  text-align:center;
  min-height:38px;
}
.wc-block-product-template .wp-block-post-title a,
.wp-block-woocommerce-product-template .wp-block-post-title a{
  color:var(--inv-text) !important;text-decoration:none;
}
.wc-block-product-template .wc-block-components-product-price,
.wp-block-woocommerce-product-template .wc-block-components-product-price,
ul.products li.product .price{
  text-align:center;font-size:17px !important;
}

.wc-block-product-template > .wp-block-post{
  border:1px solid #eef1f4;
  border-radius:8px;
  padding:14px;
  background:#fff;
  transition:box-shadow .2s, transform .2s;
  display:flex;flex-direction:column;align-items:center;
}
.wc-block-product-template > .wp-block-post:hover{
  box-shadow:0 6px 24px rgba(6,42,63,.10);
  transform:translateY(-2px);
}
.wc-block-product-template img{max-width:100%;height:auto;}
.wc-block-components-product-price{color:var(--inv-text);font-weight:700;font-size:18px !important;margin:8px 0;}
.wp-block-button.wc-block-components-product-button .wp-block-button__link{
  background:var(--inv-primary);
  color:#fff;
  border-radius:4px;
  padding:8px 16px;
  font-weight:600;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.5px;
}
.wp-block-button.wc-block-components-product-button .wp-block-button__link:hover{background:#15a55f;}

/* ---------- Footer ---------- */
/* Mismo problema que el header: el template-part viene con
   has-global-padding + is-layout-constrained — forzamos full-width. */
footer.site-footer.has-global-padding{
  padding-left:0 !important;
  padding-right:0 !important;
  max-width:none !important;
}
.site-footer > .wp-block-group{
  max-width:none !important;
  width:100% !important;
  box-sizing:border-box;
}
.site-footer{margin-top:64px;}
.kitdigital-banner .kitdigital-img img{max-width:100%;height:auto;border-radius:4px;}
.site-footer h4{color:#fff !important;margin-bottom:16px;font-weight:700;}
.footer-nav-list{list-style:none;padding:0;margin:0;}
.footer-nav-list li{margin:8px 0;}
/* Doble selector con id-level specificity para vencer al estilo global de WP que pinta <a> en verde */
html body .site-footer .footer-nav-list a,
html body footer.site-footer ul.footer-nav-list li a,
html body footer.site-footer a{
  color:#fff !important;
  text-decoration:none;
  font-size:14px;font-weight:500;
  opacity:.95;
  transition:opacity .15s
}
html body .site-footer .footer-nav-list a:hover,
html body footer.site-footer a:hover{
  color:#fff !important;opacity:1;text-decoration:underline
}
.footer-social{margin-top:14px;}
.footer-social .wp-block-social-link{background:rgba(255,255,255,.18);border-radius:50%;}
.footer-social .wp-block-social-link:hover{background:var(--inv-primary);}
.footer-logo img{background:#fff !important;padding:12px !important;border-radius:8px !important;}
.site-footer a{color:#fff !important;}
.site-footer a:hover{color:#fff !important;text-decoration:underline}
.site-footer .footer-contact-list svg{color:#fff;opacity:.85}
.kitdigital-banner{background:rgba(255,255,255,.06);border-top:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18)}

/* ---------- Tipografía global ---------- */
body{color:var(--inv-text);}
h1,h2,h3,h4{color:var(--inv-text);}

/* Fix vertical para flex items en cabecera (alineación logo/menú/acciones) */
.site-header .wp-block-group.is-layout-flex{align-items:center;}

/* ============================================================
   ARCHIVE PRODUCT (categoría / shop)
   ============================================================ */
.archive-hero{border-bottom:1px solid #d9ede2;}
.archive-hero .wp-block-query-title{margin:.25rem 0;}
.archive-hero .wc-block-components-breadcrumbs,
.product-breadcrumb-bar .wc-block-components-breadcrumbs{font-size:13px;color:var(--inv-text-soft);}
.archive-hero .wc-block-components-breadcrumbs a,
.product-breadcrumb-bar .wc-block-components-breadcrumbs a{color:var(--inv-text-soft);text-decoration:none;}
.archive-hero .wc-block-components-breadcrumbs a:hover,
.product-breadcrumb-bar .wc-block-components-breadcrumbs a:hover{color:var(--inv-primary);}

/* Toolbar (results + sort) */
.archive-toolbar{border-bottom:1px solid #eef1f4;}
.archive-toolbar .results-count{color:var(--inv-text-soft);font-size:14px;margin:0;}
.archive-toolbar select,
.archive-toolbar .catalog-sort select{
  border:1px solid #dfe5ec;border-radius:4px;padding:8px 32px 8px 12px;
  font-size:14px;background:#fff;color:var(--inv-text);cursor:pointer;
}

/* Grid de archive */
.archive-grid .wc-block-product-template{
  display:grid !important;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  list-style:none;padding:0;margin:0;
}
@media (max-width:1024px){.archive-grid .wc-block-product-template{grid-template-columns:repeat(3,1fr);}}
@media (max-width:782px){.archive-grid .wc-block-product-template{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.archive-grid .wc-block-product-template{grid-template-columns:1fr;}}

.archive-grid .wp-block-post{
  border:1px solid #eef1f4;
  border-radius:8px;
  padding:14px;
  background:#fff;
  display:flex;flex-direction:column;align-items:stretch;
  transition:box-shadow .2s, transform .2s;
}
.archive-grid .wp-block-post:hover{
  box-shadow:0 6px 24px rgba(6,42,63,.10);
  transform:translateY(-2px);
}
.archive-grid .wp-block-post img{width:100%;height:auto;}
.archive-grid .wc-block-components-product-sale-badge{
  background:var(--inv-accent);color:#fff;font-weight:700;border-radius:4px;font-size:11px;padding:4px 8px;letter-spacing:.5px;
}

/* Paginación */
.inv-pagination{margin-top:40px;}
.inv-pagination a,.inv-pagination span{
  display:inline-block;min-width:38px;padding:8px 12px;
  border:1px solid #dfe5ec;border-radius:4px;
  text-decoration:none;color:var(--inv-text);font-weight:600;text-align:center;
  background:#fff;
}
.inv-pagination .current,
.inv-pagination a:hover{
  background:var(--inv-primary);color:#fff;border-color:var(--inv-primary);
}
.inv-pagination .wp-block-query-pagination-previous,
.inv-pagination .wp-block-query-pagination-next{padding:8px 16px;}

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.product-breadcrumb-bar{border-bottom:1px solid #eef1f4;}

.product-hero .product-gallery-col .woocommerce-product-gallery,
.product-hero .product-gallery-col img{max-width:100%;border-radius:8px;}
.product-hero .product-gallery-col img{border:1px solid #eef1f4;}

.product-info-col .inv-rating{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--inv-text-soft);}
.product-info-col .inv-rating .star-rating{margin:0;}

/* Precio destacado */
.product-info-col .inv-price-big .price,
.product-info-col .inv-price-big{
  font-size:28px !important;font-weight:800 !important;color:var(--inv-primary) !important;
  display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;
}
.product-info-col .inv-price-big del{color:#94a3b8 !important;font-size:18px !important;font-weight:600 !important;}
.product-info-col .inv-price-big ins{text-decoration:none;}

/* Stock */
.product-info-col .inv-stock{
  display:inline-block;padding:6px 12px;border-radius:4px;font-size:13px;font-weight:600;
  background:var(--inv-secondary);color:var(--inv-primary);margin-bottom:16px;
}
.product-info-col .inv-stock.out-of-stock{background:#fee2e2;color:#dc2626;}

/* Add to cart form */
.product-info-col .inv-add-to-cart .quantity input.qty,
.product-info-col .inv-add-to-cart input.qty{
  width:80px;height:48px;border:1px solid #dfe5ec;border-radius:4px;padding:0 12px;
  font-size:16px;text-align:center;
}
.product-info-col .inv-add-to-cart .single_add_to_cart_button,
.product-info-col .inv-add-to-cart button[type="submit"]{
  background:var(--inv-primary) !important;color:#fff !important;
  padding:14px 32px !important;font-size:14px !important;font-weight:700 !important;
  text-transform:uppercase;letter-spacing:1px;border-radius:4px !important;border:none !important;
  cursor:pointer;transition:background .2s;
  margin-left:12px;height:48px;
}
.product-info-col .inv-add-to-cart .single_add_to_cart_button:hover,
.product-info-col .inv-add-to-cart button[type="submit"]:hover{background:#15a55f !important;}
.product-info-col .inv-add-to-cart form.cart{display:flex;align-items:center;flex-wrap:wrap;gap:0;}

/* Meta (SKU, categories, tags) */
.product-info-col .inv-meta,
.product-info-col .product_meta{font-size:13px;color:var(--inv-text-soft);}
.product-info-col .inv-meta span,
.product-info-col .product_meta > span{display:block;margin:4px 0;}
.product-info-col .inv-meta strong{color:var(--inv-text);}

/* Tabs producto */
.product-tabs-section .wp-block-woocommerce-product-details{border-top:1px solid #e2e8f0;}
.product-tabs-section .wc-tabs,
.product-tabs-section ul.tabs{
  display:flex;gap:0;list-style:none;padding:0;margin:0 0 24px;border-bottom:2px solid #e2e8f0;
}
.product-tabs-section .wc-tabs li,
.product-tabs-section ul.tabs li{
  padding:14px 24px;cursor:pointer;font-weight:700;color:var(--inv-text-soft);
  border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;
}
.product-tabs-section .wc-tabs li.active,
.product-tabs-section ul.tabs li.active{
  color:var(--inv-primary);border-bottom-color:var(--inv-primary);
}
.product-tabs-section .woocommerce-Tabs-panel{padding:16px 0;}
.product-tabs-section .woocommerce-Tabs-panel h2{display:none;}

/* Related */
.related-products-section .wc-block-product-template,
.related-products-section .products{
  display:grid !important;grid-template-columns:repeat(4,1fr);gap:24px;list-style:none;padding:0;margin:0;
}
@media (max-width:1024px){.related-products-section .wc-block-product-template,.related-products-section .products{grid-template-columns:repeat(3,1fr);}}
@media (max-width:782px){.related-products-section .wc-block-product-template,.related-products-section .products{grid-template-columns:repeat(2,1fr);}}

.related-products-section .wp-block-post,
.related-products-section li.product{
  border:1px solid #eef1f4;border-radius:8px;padding:14px;background:#fff;
  transition:box-shadow .2s,transform .2s;
}
.related-products-section .wp-block-post:hover,
.related-products-section li.product:hover{
  box-shadow:0 6px 24px rgba(6,42,63,.10);transform:translateY(-2px);
}

/* Single product mobile */
@media (max-width:782px){
  .product-hero .wp-block-columns{flex-direction:column !important;}
  .product-hero .wp-block-column{flex-basis:100% !important;}
  .product-info-col .inv-add-to-cart form.cart{justify-content:flex-start;}
  .product-info-col .inv-add-to-cart .single_add_to_cart_button{margin-left:0;margin-top:12px;width:100%;}
}

/* ============================================================
   CART · CHECKOUT · MY ACCOUNT
   ============================================================ */
.page-hero{border-bottom:1px solid #d9ede2;}
.page-hero .wc-block-components-breadcrumbs,
.page-hero .wc-block-components-breadcrumbs a{color:var(--inv-text-soft);}
.page-hero .wc-block-components-breadcrumbs a:hover{color:var(--inv-primary);}

/* Cart line items */
.cart-wrap .wp-block-woocommerce-cart-line-items-block{background:#fff;border:1px solid #eef1f4;border-radius:8px;padding:8px 16px;}
.cart-wrap .wc-block-cart-items__row{padding:18px 0;border-bottom:1px solid #f1f5f9;}
.cart-wrap .wc-block-cart-items__row:last-child{border-bottom:none;}
.cart-wrap .wc-block-cart-item__image img{border-radius:6px;border:1px solid #eef1f4;max-width:80px;}
.cart-wrap .wc-block-cart-item__product-name,
.cart-wrap .wc-block-cart-item__product-name a{color:var(--inv-text);font-weight:700;text-decoration:none;font-size:15px;}
.cart-wrap .wc-block-cart-item__product-name a:hover{color:var(--inv-primary);}
.cart-wrap .wc-block-components-product-price{color:var(--inv-text);font-weight:700;}

/* Quantity selector en cart/checkout */
.cart-wrap .wc-block-components-quantity-selector,
.checkout-wrap .wc-block-components-quantity-selector{border:1px solid #dfe5ec;border-radius:4px;}
.cart-wrap .wc-block-components-quantity-selector button,
.checkout-wrap .wc-block-components-quantity-selector button{color:var(--inv-text);font-weight:700;}

/* Order summary box */
.cart-wrap .wp-block-woocommerce-cart-order-summary-block,
.checkout-wrap .wp-block-woocommerce-checkout-order-summary-block{
  background:#fff;border:1px solid #eef1f4;border-radius:8px;padding:24px;
}
.cart-wrap .wc-block-components-totals-item,
.checkout-wrap .wc-block-components-totals-item{padding:8px 0;}
.cart-wrap .wc-block-components-totals-footer-item,
.checkout-wrap .wc-block-components-totals-footer-item{
  border-top:2px solid #e2e8f0;padding-top:14px !important;margin-top:6px !important;
}
.cart-wrap .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.checkout-wrap .wc-block-components-totals-footer-item .wc-block-components-totals-item__value{
  color:var(--inv-primary);font-size:24px;font-weight:800;
}

/* Botón "Finalizar compra" / "Realizar pedido" */
.cart-wrap .wc-block-cart__submit-button,
.cart-wrap .wp-block-woocommerce-proceed-to-checkout-block .wc-block-cart__submit-container button,
.checkout-wrap .wc-block-components-checkout-place-order-button{
  background:var(--inv-primary) !important;color:#fff !important;
  padding:14px 28px !important;font-size:14px !important;font-weight:700 !important;
  text-transform:uppercase;letter-spacing:1px;border-radius:4px !important;border:none !important;
  cursor:pointer;transition:background .2s;width:100%;
}
.cart-wrap .wc-block-cart__submit-button:hover,
.checkout-wrap .wc-block-components-checkout-place-order-button:hover{background:#15a55f !important;}

/* Cupon */
.cart-wrap .wc-block-components-totals-coupon-link,
.checkout-wrap .wc-block-components-totals-coupon-link{color:var(--inv-primary);font-weight:600;}

/* Checkout secciones (steps) */
.checkout-wrap .wc-block-components-checkout-step{
  background:#fff;border:1px solid #eef1f4;border-radius:8px;padding:24px;margin-bottom:16px;
}
.checkout-wrap .wc-block-components-checkout-step__heading,
.checkout-wrap .wc-block-components-checkout-step__title{
  color:var(--inv-text);font-weight:700;font-size:18px;
}
.checkout-wrap .wc-block-components-text-input input,
.checkout-wrap .wc-block-components-select select,
.checkout-wrap .wc-block-components-textarea textarea{
  border:1px solid #dfe5ec !important;border-radius:4px !important;
  font-size:15px;
}
.checkout-wrap .wc-block-components-text-input.is-active label,
.checkout-wrap .wc-block-components-text-input input:focus + label{color:var(--inv-primary);}

/* Métodos de pago */
.checkout-wrap .wc-block-components-payment-method-label{font-weight:600;color:var(--inv-text);}
.checkout-wrap .wc-block-components-radio-control__input:checked{border-color:var(--inv-primary) !important;}

/* Vacio cart message */
.cart-wrap .empty-cart-title{margin-top:0;}

/* MY ACCOUNT (uses woocommerce shortcode) */
.myaccount-wrap .woocommerce{display:flex;gap:32px;flex-wrap:wrap;}
.myaccount-wrap .woocommerce-MyAccount-navigation{flex:0 0 240px;}
.myaccount-wrap .woocommerce-MyAccount-content{flex:1;min-width:300px;background:#fff;border:1px solid #eef1f4;border-radius:8px;padding:24px;}
.myaccount-wrap .woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0;border:1px solid #eef1f4;border-radius:8px;overflow:hidden;background:#fff;}
.myaccount-wrap .woocommerce-MyAccount-navigation li{border-bottom:1px solid #eef1f4;}
.myaccount-wrap .woocommerce-MyAccount-navigation li:last-child{border-bottom:none;}
.myaccount-wrap .woocommerce-MyAccount-navigation li a{display:block;padding:14px 18px;color:var(--inv-text);text-decoration:none;font-weight:600;}
.myaccount-wrap .woocommerce-MyAccount-navigation li.is-active a,
.myaccount-wrap .woocommerce-MyAccount-navigation li a:hover{background:var(--inv-secondary);color:var(--inv-primary);}

/* Login + register forms (no logueado) */
.myaccount-wrap form.woocommerce-form{background:#fff;border:1px solid #eef1f4;border-radius:8px;padding:32px;max-width:480px;}
.myaccount-wrap form.woocommerce-form-login,
.myaccount-wrap form.woocommerce-form-register{margin-bottom:24px;}
.myaccount-wrap form.woocommerce-form input[type="text"],
.myaccount-wrap form.woocommerce-form input[type="email"],
.myaccount-wrap form.woocommerce-form input[type="password"]{
  width:100%;padding:10px 14px;border:1px solid #dfe5ec;border-radius:4px;font-size:15px;
}
.myaccount-wrap form.woocommerce-form button[type="submit"],
.myaccount-wrap form.woocommerce-form .woocommerce-button{
  background:var(--inv-primary) !important;color:#fff !important;border:none !important;
  padding:12px 28px !important;border-radius:4px !important;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;font-size:14px;cursor:pointer;
}
.myaccount-wrap form.woocommerce-form button[type="submit"]:hover{background:#15a55f !important;}

/* My account mobile */
@media (max-width:782px){
  .myaccount-wrap .woocommerce{flex-direction:column;}
  .myaccount-wrap .woocommerce-MyAccount-navigation{flex-basis:auto;}
}

/* ============================================================
   PAGE LAYOUT — full-width pages estáticas
   WP nulifica el margin negativo de alignfull dentro de wrappers con
   global padding. Forzamos override con calc del root padding.
   ============================================================ */
main.page-main{
  padding-top:0 !important;
  padding-bottom:0 !important;
}
main.page-main .entry-content,
main.page-main > .wp-block-post-content{
  max-width:none !important;
  padding:0 !important;
}
/* Contenido NO-alignfull queda centrado con max-width como pro1 */
main.page-main .entry-content > :where(:not(.alignfull):not(.alignwide)),
main.page-main > .wp-block-post-content > :where(:not(.alignfull):not(.alignwide)){
  max-width: var(--wp--style--global--content-size, 1280px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--wp--style--root--padding-left, 24px);
  padding-right: var(--wp--style--root--padding-right, 24px);
}
/* Alignfull SÍ borde-a-borde (margin negativo del root padding) */
main.page-main .alignfull,
main.page-main .entry-content > .wp-block-group.alignfull{
  margin-left: calc(var(--wp--style--root--padding-left, 24px) * -1) !important;
  margin-right: calc(var(--wp--style--root--padding-right, 24px) * -1) !important;
  max-width: none !important;
  width: auto !important;
}

/* ============================================================
   Page hero images — proporciones controladas
   ============================================================ */
.wp-block-cover.hero{min-height:440px !important;}
@media (max-width:782px){ .wp-block-cover.hero{min-height:320px !important;} }
main .wp-block-image img{max-height:340px;width:auto;object-fit:cover;border-radius:8px;}
main .wp-block-cover img.wp-block-cover__image-background{max-height:none;}
main .wp-block-columns .wp-block-image img{max-height:360px;}
/* Servicios cards: imágenes uniformes */
main .wp-block-columns .wp-block-column > .wp-block-image:first-child img{aspect-ratio:4/3;max-height:240px;width:100%;object-fit:cover;}

/* ============================================================
   Shop filters sidebar
   ============================================================ */
.wp-block-group.shop-with-filters{
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-start !important;
  gap:32px !important;
  max-width:none !important;
}
.wp-block-group.shop-with-filters > .shop-sidebar{
  flex:0 0 260px !important;
  width:260px !important;
  max-width:260px !important;
}
.wp-block-group.shop-with-filters > .shop-grid-main,
.wp-block-group.shop-with-filters > .archive-grid,
.wp-block-group.shop-with-filters > .wp-block-woocommerce-product-collection{
  flex:1 1 auto !important;
  min-width:0 !important;
  max-width:calc(100% - 292px) !important;
}
@media (max-width:900px){
  .wp-block-group.shop-with-filters{flex-direction:column !important;}
  .wp-block-group.shop-with-filters > .shop-sidebar,
  .wp-block-group.shop-with-filters > .shop-grid-main,
  .wp-block-group.shop-with-filters > .archive-grid{flex:1 1 auto !important;width:100% !important;max-width:100% !important;}
}
/* Mobile: sidebar como acordeón colapsable (FAB "Filtros") */
@media (max-width:782px){
  .shop-sidebar{position:static !important;max-height:0;overflow:hidden;padding:0 !important;border:none !important;transition:max-height .3s;}
  .shop-sidebar.is-open{max-height:2000px;padding:16px !important;border:1px solid #eef1f4 !important;margin-bottom:16px;}
  .inv-filters-toggle{
    display:flex;align-items:center;justify-content:center;gap:8px;
    width:100%;margin:12px 0;padding:12px 16px;
    background:var(--inv-primary);color:#fff;font-weight:700;border:none;border-radius:6px;
    cursor:pointer;font-size:14px;text-transform:uppercase;letter-spacing:.5px;
  }
  .inv-filters-toggle .icon{display:inline-block;width:18px;height:18px;}
}
@media (min-width:783px){.inv-filters-toggle{display:none !important;}}
.shop-sidebar{background:#fff;border:1px solid #eef1f4;border-radius:8px;padding:18px 20px;height:fit-content;position:sticky;top:90px;}
.shop-sidebar h3{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--inv-text);margin:18px 0 10px;border-top:1px solid #eef1f4;padding-top:18px;}
.shop-sidebar h3:first-child{border-top:none;padding-top:0;margin-top:0;}
.shop-sidebar ul{list-style:none;padding:0;margin:0;max-height:240px;overflow-y:auto;}
.shop-sidebar ul li{padding:5px 0;font-size:13px;color:var(--inv-text-soft);}
.shop-sidebar ul li a{color:var(--inv-text-soft);text-decoration:none;display:flex;justify-content:space-between;}
.shop-sidebar ul li a:hover{color:var(--inv-primary);}
.shop-sidebar input[type="checkbox"]{accent-color:var(--inv-primary);margin-right:6px;}
.shop-sidebar .filter-price input[type="range"]{accent-color:var(--inv-primary);width:100%;}

/* ============================================================
   RESPONSIVE GLOBAL — mobile-first refinement
   Breakpoints:
     mobile  ≤480px
     phone   ≤600px
     tablet  ≤782px (límite WP por defecto)
     laptop  ≤1024px
     desktop ≤1440px
     wide    ≥1441px
   ============================================================ */

/* ---------- Layout & containers ---------- */
:root{
  --inv-container:1280px;
  --inv-gutter:16px;
}
@media (max-width:782px){
  :root{ --inv-gutter:12px; }
}
.wp-block-group.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)){
  max-width:var(--inv-container);
}

/* ---------- Imágenes nunca desbordan ---------- */
img, picture, video{max-width:100%;height:auto;}

/* ---------- Anti-overflow horizontal en mobile ---------- */
@media (max-width:782px){
  html, body{overflow-x:hidden;max-width:100vw;}
  /* Textos largos se rompen */
  .site-footer p, .site-footer h4, .site-footer h2,
  .hero h1, .hero h2, .hero p,
  .archive-hero h1, .archive-hero p,
  main p, main h1, main h2, main h3{
    word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;
  }
  /* Footer columnas: padding interno + word-break */
  .site-footer .wp-block-column,
  .footer-main .wp-block-column{
    padding:0 8px;min-width:0 !important;
  }
}

/* ---------- HEADER responsive ---------- */
/* Tablet: oculta el campo de búsqueda inline (se mueve a un drawer/icono futuro) */
@media (max-width:1024px){
  .header-search input[type="search"]{min-width:140px;font-size:13px;}
  .site-header .wp-block-navigation a{padding:.4em .55em;font-size:14px;}
}
/* Tablet-medio: ocultar texto de la cuenta, queda solo icono mini-cart visible */
@media (max-width:900px){
  .header-actions .header-search{display:none;}
  .topbar{font-size:12px;padding:5px 12px !important;}
  .topbar .topbar-msg{font-size:12px;}
}
/* Móvil: el nav WP usa el hamburguesa nativo si está mark-up correcto */
@media (max-width:782px){
  .site-header .header-main{padding:8px 12px !important;flex-wrap:wrap;gap:8px;}
  .site-header .site-logo img{max-height:44px;}
  .header-account{display:none;}
  .header-actions{gap:8px;flex-wrap:wrap;}
  /* Nav block: el bloque navigation activa el overlay/hamburguesa solo si tiene overlayMenu mobile.
     Forzamos comportamiento responsive: el menú desktop se oculta y aparece el botón hamburguesa. */
  .site-header .wp-block-navigation__container{display:none;}
  .site-header .wp-block-navigation__responsive-container-open{display:flex !important;}
  /* Reducir botón Acceder/Regístrate en mobile */
  .header-account-btn,
  .site-header a[href*="/mi-cuenta"]{
    font-size:13px !important;padding:8px 14px !important;letter-spacing:0 !important;
  }
  /* Topbar más compacto */
  .inv-topbar{font-size:12px !important;padding:6px 10px !important;}
}
/* Móvil pequeño */
@media (max-width:480px){
  .inv-topbar{display:none !important;}
  .site-header .site-logo img{max-height:36px;}
  .header-account-btn,
  .site-header a[href*="/mi-cuenta"]{font-size:12px !important;padding:6px 10px !important;}
  /* Mini cart count */
  .header-cart .wc-block-mini-cart__amount{display:none;}
}

/* WhatsApp + Google Translate posicionados sin overlap en mobile */
@media (max-width:600px){
  #inv-wa{
    bottom:14px !important;right:14px !important;
    padding:14px !important;border-radius:50% !important;
    width:56px;height:56px;justify-content:center !important;gap:0 !important;
  }
  #inv-wa .inv-wa-text{display:none !important;}
  #inv-translator,
  #google_translate_element{bottom:14px !important;left:14px !important;}
}

/* ---------- HERO responsive ---------- */
@media (max-width:1024px){
  .hero .hero-title{font-size:44px !important;}
  .hero{min-height:440px !important;}
}
@media (max-width:782px){
  .hero .hero-title,
  .hero h1, .hero h2{
    font-size:26px !important;letter-spacing:0 !important;line-height:1.2 !important;
    word-wrap:break-word !important;overflow-wrap:anywhere !important;
    max-width:100% !important;
  }
  .hero{min-height:360px !important;padding:24px 16px !important;box-sizing:border-box !important;}
  .hero > .wp-block-group, .hero .wp-block-group{padding-left:0 !important;padding-right:0 !important;}
  .hero .wp-block-paragraph,
  .hero p{font-size:14px !important;line-height:1.4 !important;}
  .hero .wp-block-buttons{flex-direction:column;gap:10px;}
  .hero .wp-block-button a{width:100%;text-align:center;}
  /* Hero columnas: stack siempre */
  .hero .wp-block-columns{flex-direction:column !important;gap:18px !important;}
  .hero .wp-block-column{flex-basis:100% !important;width:100% !important;}
  .hero .wp-block-image img{max-height:220px;object-fit:cover;}
}
@media (max-width:480px){
  .hero .hero-title,
  .hero h1, .hero h2{font-size:22px !important;}
  .hero{min-height:300px !important;padding:24px 14px !important;}
  .hero p, .hero .wp-block-paragraph{font-size:13px !important;}
}

/* ---------- SERVICES STRIP responsive ---------- */
@media (max-width:782px){
  .services-strip{padding:32px 12px !important;}
  .services-strip .wp-block-columns{flex-direction:column;gap:24px;}
  .services-strip .wp-block-column{padding:8px;}
  .services-strip h3{font-size:18px !important;margin-top:8px !important;}
}

/* ---------- ARCHIVE responsive ---------- */
@media (max-width:782px){
  .archive-hero{padding:24px 12px 18px !important;}
  .archive-hero .wp-block-query-title{font-size:24px !important;letter-spacing:0 !important;word-break:break-word;}
  .archive-hero .wp-block-paragraph{font-size:14px !important;}
  .archive-toolbar{padding:14px 12px !important;}
  .archive-toolbar .wp-block-group.is-layout-flex{flex-direction:column;align-items:flex-start;gap:8px;}
  .archive-toolbar select{width:100%;}
  .archive-grid{padding:8px 12px 40px !important;}
}

/* Card de producto: tamaño de texto y padding */
@media (max-width:782px){
  .archive-grid .wp-block-post,
  .related-products-section .wp-block-post,
  .wc-block-product-template .wp-block-post{padding:10px;}
  .wc-block-components-product-price{font-size:14px !important;}
  .archive-grid .wp-block-post .wp-block-post-title,
  .archive-grid .wp-block-post h3,
  .archive-grid .wp-block-post .wc-block-components-product-name{
    font-size:13px !important;line-height:1.25 !important;word-break:break-word;hyphens:auto;
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
  }
  .archive-grid .wc-block-components-product-button .wp-block-button__link{
    font-size:12px !important;padding:8px 10px !important;
  }
}

/* GLOBAL fallback: aplica grid responsive a TODOS los product templates
   (FSE block puede no llevar parent .archive-grid en todos los contextos) */
@media (max-width:1280px){
  .wp-block-woocommerce-product-collection .wc-block-product-template,
  ul.wc-block-product-template{grid-template-columns:repeat(4,1fr) !important;}
}
@media (max-width:1024px){
  .wp-block-woocommerce-product-collection .wc-block-product-template,
  ul.wc-block-product-template{grid-template-columns:repeat(3,1fr) !important;}
}
@media (max-width:782px){
  .wp-block-woocommerce-product-collection .wc-block-product-template,
  ul.wc-block-product-template{grid-template-columns:repeat(2,1fr) !important;gap:12px !important;}
}
@media (max-width:380px){
  .wp-block-woocommerce-product-collection .wc-block-product-template,
  ul.wc-block-product-template{grid-template-columns:1fr !important;}
}

/* Paginación en móvil: scroll horizontal si muchos números */
@media (max-width:600px){
  .inv-pagination{flex-wrap:wrap;justify-content:center;gap:6px;}
  .inv-pagination a,.inv-pagination span{min-width:34px;padding:6px 10px;font-size:14px;}
}

/* ---------- SINGLE PRODUCT responsive ---------- */
@media (max-width:1024px){
  .product-hero{padding:24px 12px 32px !important;}
  .product-info-col .wp-block-post-title{font-size:26px !important;}
  .product-info-col .inv-price-big{font-size:24px !important;}
}
@media (max-width:782px){
  .product-hero .wp-block-columns{flex-direction:column !important;gap:24px !important;}
  .product-hero .wp-block-column{flex-basis:100% !important;width:100% !important;}
  .product-info-col .wp-block-post-title{font-size:22px !important;letter-spacing:0 !important;}
  .product-info-col .inv-price-big{font-size:22px !important;}
  .product-info-col .inv-add-to-cart form.cart{flex-direction:column;align-items:stretch;}
  .product-info-col .inv-add-to-cart .single_add_to_cart_button{margin-left:0 !important;margin-top:10px !important;width:100% !important;}
  .product-info-col .inv-add-to-cart .quantity input.qty{width:100%;}
  .product-tabs-section{padding:16px 12px 32px !important;}
  .product-tabs-section .wc-tabs li,
  .product-tabs-section ul.tabs li{padding:10px 14px;font-size:14px;}
  .related-products-section{padding:32px 12px 48px !important;}
  .related-products-section h2{font-size:22px !important;}
}

/* ---------- CART / CHECKOUT responsive ---------- */
@media (max-width:1024px){
  .cart-wrap, .checkout-wrap{padding:24px 12px 48px !important;}
}
@media (max-width:782px){
  .page-hero{padding:24px 12px 16px !important;}
  .page-hero h1{font-size:26px !important;letter-spacing:0 !important;}
  .cart-wrap, .checkout-wrap{padding:16px 12px 40px !important;}
  /* Stack carrito y totals */
  .cart-wrap .wp-block-woocommerce-filled-cart-block,
  .checkout-wrap .wp-block-woocommerce-checkout{flex-direction:column !important;display:flex !important;gap:18px !important;}
  .cart-wrap .wp-block-woocommerce-cart-items-block,
  .cart-wrap .wp-block-woocommerce-cart-totals-block,
  .checkout-wrap .wp-block-woocommerce-checkout-fields-block,
  .checkout-wrap .wp-block-woocommerce-checkout-totals-block{
    width:100% !important;flex:1 1 100% !important;
  }
  /* Items row stacking */
  .cart-wrap .wc-block-cart-items__row{flex-wrap:wrap;}
  .cart-wrap .wc-block-cart-item__image{flex-basis:80px;}
}
@media (max-width:480px){
  .cart-wrap .wc-block-cart-item__image img{max-width:64px;}
}

/* ---------- FOOTER responsive ---------- */
@media (max-width:1024px){
  .footer-main .wp-block-columns{gap:24px !important;}
  .footer-main .wp-block-column{flex-basis:calc(50% - 12px) !important;}
}
@media (max-width:782px){
  .footer-main{padding:32px 12px 24px !important;}
  .footer-main .wp-block-columns{flex-direction:column !important;gap:32px !important;}
  .footer-main .wp-block-column{flex-basis:100% !important;}
  .kitdigital-banner{padding:12px !important;}
  .site-footer h4{margin-bottom:10px;}
}

/* ---------- WIDE / 4K (≥1441px) ---------- */
@media (min-width:1441px){
  :root{ --inv-container:1380px; }
  .hero .hero-title{font-size:64px !important;}
  .wc-block-product-template{gap:28px !important;}
}
@media (min-width:1920px){
  :root{ --inv-container:1500px; }
  .archive-grid .wc-block-product-template,
  .related-products-section .wc-block-product-template,
  .related-products-section .products{grid-template-columns:repeat(5,1fr) !important;}
}

/* ---------- Tap targets (a11y mobile) ---------- */
@media (hover:none){
  a, button, .wp-block-button__link{min-height:40px;}
  .footer-nav-list a{padding:6px 0;}
}

/* ---------- Print ---------- */
@media print{
  .topbar, .site-header .header-actions, .site-footer, .related-products-section{display:none !important;}
  .product-hero, .archive-grid{padding:0 !important;}
}
