/* ==========================================================================
   MAIN CSS - Loaded async (non-blocking)
   Below-the-fold: single product, footer, mobile menu, pagination, etc.
   ========================================================================== */

/* ==========================================================================
   MOBILE OFF-CANVAS MENU
   ========================================================================== */
.mobile-menu{position:fixed;top:0;left:0;width:100%;height:100%;z-index:200;visibility:hidden;pointer-events:none}
.mobile-menu.is-open{visibility:visible;pointer-events:auto}
.mobile-menu-overlay{position:absolute;inset:0;background:var(--c-overlay);opacity:0;transition:opacity .3s var(--ease)}
.mobile-menu.is-open .mobile-menu-overlay{opacity:1}
.mobile-menu-panel{position:absolute;top:0;left:0;width:85%;max-width:360px;height:100%;background:var(--c-bg);transform:translateX(-100%);transition:transform .3s var(--ease);overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-menu.is-open .mobile-menu-panel{transform:translateX(0)}
.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4);border-bottom:1px solid var(--c-border)}
.mobile-menu-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center}
.mobile-menu-close svg{width:20px;height:20px}
.mobile-menu-nav{overflow-y:auto;flex:1}

/* Mobile support section */
.mobile-menu-divider{height:1px;background:var(--c-border);margin:var(--s-2) var(--s-4)}
.mobile-menu-support-label{padding:var(--s-3) var(--s-4) var(--s-1);font-size:.6875rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted)}
.mobile-menu-support a{
    display:flex;align-items:center;gap:12px;
    padding:var(--s-3) var(--s-4);font-size:.875rem;font-weight:500;
    color:var(--c-text);text-decoration:none;
    border-bottom:1px solid var(--c-border);
    transition:background .15s ease;
}
.mobile-menu-support a:active{background:var(--c-surface)}
@media(hover:hover){.mobile-menu-support a:hover{background:var(--c-surface)}}
.mobile-menu-support a svg{width:20px;height:20px;flex-shrink:0;color:var(--c-text-muted)}

/* Expandable mobile menu items (recursive) */
.mm-item{border-bottom:1px solid var(--c-border)}
.mm-item .mm-item{border-bottom:none;border-top:1px solid rgba(0,0,0,.04)}
.mm-item .mm-item:last-child{border-bottom:none}

.mm-row{
    display:flex;align-items:center;gap:4px;
    padding:var(--s-3) var(--s-4);cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    transition:background .15s ease;
}
.mm-row:active{background:var(--c-surface)}
@media(hover:hover){.mm-row:hover{background:var(--c-surface)}}

.mm-name{
    flex:1;font-size:.875rem;font-weight:500;color:var(--c-text);
    min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.mm-has-children > .mm-row > .mm-name{font-weight:600}

.mm-see-all{
    font-size:.6875rem;font-weight:600;color:var(--c-primary);text-decoration:none;
    text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;
    padding:2px 8px;border-radius:4px;
    opacity:0;pointer-events:none;transition:opacity .2s ease;
}
.mm-row[aria-expanded="true"] .mm-see-all{opacity:1;pointer-events:auto}
.mm-see-all:active{background:rgba(255,107,0,.08)}

.mm-chevron{width:18px;height:18px;flex-shrink:0;color:var(--c-text-muted);transition:transform .25s ease}
.mm-row[aria-expanded="true"] .mm-chevron{transform:rotate(90deg);color:var(--c-primary)}

.mm-children{display:none;background:rgba(0,0,0,.015)}
.mm-row[aria-expanded="true"] + .mm-children{display:block}

.mm-leaf{
    display:block;padding:var(--s-3) var(--s-4);
    font-size:.875rem;font-weight:500;color:var(--c-text);text-decoration:none;
    transition:background .15s ease;border-bottom:1px solid rgba(0,0,0,.04);
}
.mm-leaf:active{background:var(--c-surface)}
@media(hover:hover){.mm-leaf:hover{background:var(--c-surface)}}
.mm-leaf:last-child{border-bottom:none}

/* ==========================================================================
   SINGLE PRODUCT PAGE
   ========================================================================== */
.single-product-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:var(--s-6);overflow:hidden}

/* Force all grid children to respect cell width */
.single-product-layout>*{min-width:0;max-width:100%}

/* Gallery - enhanced with zoom + lightbox */
.product-gallery{position:relative}
.spx-gallery-main{position:relative;border-radius:var(--radius);overflow:hidden}
.spx-gallery-viewport{aspect-ratio:5/4;overflow:hidden;position:relative;cursor:zoom-in}
.spx-gallery-viewport img{width:100%;height:100%;object-fit:contain;transform-origin:center center}
.spx-gallery-viewport.is-zoomed{cursor:zoom-out}
.spx-gallery-viewport.is-zoomed img{object-fit:cover}
.spx-gallery-zoom-hint{position:absolute;top:var(--s-3);right:var(--s-3);width:28px;height:28px;background:rgba(0,0,0,.06);border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:.8;transition:opacity var(--dur) var(--ease)}
.spx-gallery-zoom-hint svg{width:16px;height:16px;color:var(--c-text-muted)}
@media(hover:hover){.spx-gallery-main:hover .spx-gallery-zoom-hint{opacity:0}}
.spx-gallery-counter{position:absolute;bottom:var(--s-3);left:50%;transform:translateX(-50%);background:rgba(0,0,0,.6);color:#fff;font-size:.6875rem;font-weight:600;padding:4px 10px;border-radius:12px;pointer-events:none}
/* Thumbs with scroll nav */
.spx-thumbs-wrap{position:relative;margin-top:var(--s-3)}
.product-gallery-thumbs{display:flex;gap:var(--s-2);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth}
.product-gallery-thumbs::-webkit-scrollbar{display:none}
.product-gallery-thumb{flex-shrink:0;width:64px;height:64px;border:2px solid var(--c-border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:border-color var(--dur) var(--ease)}
.product-gallery-thumb.is-active{border-color:var(--c-primary)}
@media(hover:hover){.product-gallery-thumb:hover{border-color:var(--c-primary)}}
.product-gallery-thumb img{width:100%;height:100%;object-fit:contain}
.spx-thumb-arrow{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;background:var(--c-bg);border:1px solid var(--c-border);border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:2;box-shadow:0 1px 3px rgba(0,0,0,.1);transition:background var(--dur) var(--ease)}
@media(hover:hover){.spx-thumb-arrow:hover{background:var(--c-surface)}}
.spx-thumb-arrow svg{width:14px;height:14px;color:var(--c-text-secondary)}
.spx-thumb-arrow-left{left:-6px}
.spx-thumb-arrow-right{right:-6px}
.spx-thumbs-wrap.has-overflow .spx-thumb-arrow{display:flex}
/* Lightbox */
.spx-lightbox{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
.spx-lightbox.is-open{opacity:1;visibility:visible}
.spx-lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:4px;user-select:none;-webkit-user-select:none}
.spx-lightbox-close{position:absolute;top:16px;right:16px;width:40px;height:40px;background:rgba(255,255,255,.15);border:0;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
@media(hover:hover){.spx-lightbox-close:hover{background:rgba(255,255,255,.3)}}
.spx-lightbox-close svg{width:20px;height:20px;color:#fff}
.spx-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.15);border:0;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
@media(hover:hover){.spx-lightbox-nav:hover{background:rgba(255,255,255,.3)}}
.spx-lightbox-nav svg{width:20px;height:20px;color:#fff}
.spx-lightbox-prev{left:16px}
.spx-lightbox-next{right:16px}
.spx-lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:.8125rem;font-weight:500}
@media(hover:none){.spx-gallery-zoom-hint{display:none}.spx-gallery-viewport{cursor:default}}
@media(min-width:1024px){.spx-gallery-counter{display:none}}

.product-info{padding-top:var(--s-2)}
.product-info h1{font-size:1.25rem;font-weight:800;line-height:1.3;color:var(--c-text);margin-bottom:var(--s-3);word-wrap:break-word;overflow-wrap:break-word}
.product-info .star-rating{margin-bottom:var(--s-3)}
.product-info .product-price{margin-bottom:var(--s-1)}
.product-info .product-price .current{font-size:1.5rem;font-weight:600}
.product-info .product-price + .info-badge-content{margin-bottom:var(--s-2)}
.product-info .product-price .info-badge-inline{align-self:center}
.product-info .short-description{font-size:.8125rem;color:var(--c-text-secondary);line-height:1.7;margin-bottom:var(--s-4);word-wrap:break-word;overflow-wrap:break-word}

/* Info badges (imported / taxes) */
.product-info-badges{display:flex;flex-wrap:wrap;gap:var(--s-2);margin-bottom:var(--s-3)}
.info-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:20px;font-size:.6875rem;font-weight:500;color:var(--c-text-secondary);cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap}
@media(hover:hover){.info-badge:hover{border-color:var(--c-text-muted);color:var(--c-text)}}
.info-badge:active{border-color:var(--c-text-muted);color:var(--c-text)}
.info-badge-inline{padding:3px 10px;background:transparent;border:1px solid var(--c-border)}
.info-badge-inline .info-badge-icon-svg{width:12px;height:12px}
.info-badge-inline .info-badge-label{font-size:.625rem}
.info-badge-inline .info-badge-chevron{width:10px;height:10px}
.info-badge-icon{font-size:.875rem;line-height:1}
.info-badge-icon-svg{width:14px;height:14px;flex-shrink:0;color:var(--c-text-muted)}
.info-badge-label{font-size:.6875rem}
.info-badge-chevron{width:12px;height:12px;flex-shrink:0;color:var(--c-text-muted);transition:transform var(--dur) var(--ease)}
.info-badge[aria-expanded="true"] .info-badge-chevron{transform:rotate(180deg)}
.info-badge-content{padding:var(--s-3) var(--s-4);background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);font-size:.75rem;line-height:1.6;color:var(--c-text-secondary);margin-bottom:var(--s-2)}
.info-badge-content a{color:var(--c-primary);text-decoration:underline;text-underline-offset:2px}
@media(hover:hover){.info-badge-content a:hover{color:var(--c-primary-hover)}}

/* Product meta rows (category, brand, SKU) */
.product-meta-section{margin-top:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--c-border)}
.product-meta-row{display:flex;align-items:baseline;gap:var(--s-2);padding:var(--s-1) 0;font-size:.8125rem}
.product-meta-label{color:var(--c-text-muted);font-weight:500;flex-shrink:0;min-width:70px}
.product-meta-value{color:var(--c-text-secondary)}
.product-meta-value a{color:var(--c-text-secondary);transition:color var(--dur) var(--ease)}
@media(hover:hover){.product-meta-value a:hover{color:var(--c-primary)}}

/* Sobre este item */
.product-about{margin-top:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--c-border)}
.product-about-title{font-size:.875rem;font-weight:700;color:var(--c-text);margin-bottom:var(--s-3)}
.product-about-content{font-size:.8125rem;line-height:1.7;color:var(--c-text-secondary);word-wrap:break-word;overflow-wrap:break-word}
.product-about-content p{margin-bottom:var(--s-3)}
.product-about-content ul,.product-about-content ol{padding-left:var(--s-4);margin-bottom:var(--s-3)}
.product-about-content li{margin-bottom:var(--s-1)}
.product-about-content img{max-width:100%;height:auto}

/* Variation Swatches — Amazon Twister cards (image + dimension + price) */
.rf-swatches{margin:var(--s-4) 0}
.rf-swatches__group{margin-bottom:var(--s-3)}
.rf-swatches__group:last-child{margin-bottom:0}
.rf-swatches__label{font-size:.8125rem;margin-bottom:var(--s-2);line-height:1.4}
.rf-swatches__label-name{font-weight:700;color:var(--c-text)}
.rf-swatches__label-value{font-weight:400;color:var(--c-text-secondary)}
.rf-swatches__options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-2)}
.rf-swatches__swatch{display:flex;align-items:center;gap:var(--s-2);text-decoration:none;border:2px solid var(--c-border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);background:var(--c-bg);padding:var(--s-2);min-height:56px;overflow:hidden}
@media(hover:hover){.rf-swatches__swatch:hover{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(255,107,0,.12);text-decoration:none}}
.rf-swatches__swatch--active{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(255,107,0,.18);pointer-events:none}
.rf-swatches__thumb{width:44px;height:44px;max-width:44px!important;max-height:44px!important;object-fit:contain;border-radius:var(--radius-sm);flex-shrink:0}
.rf-swatches__info{display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}
.rf-swatches__dim{font-size:.6875rem;font-weight:600;color:var(--c-text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
.rf-swatches__price{font-size:.75rem;font-weight:700;color:var(--c-text);line-height:1.2}
.rf-swatches__price .woocommerce-Price-amount{font-size:.75rem;font-weight:700}
@media(hover:hover){.rf-swatches__swatch:hover .rf-swatches__price{color:var(--c-primary)}}
.rf-swatches__swatch--active .rf-swatches__price{color:var(--c-primary)}
@media(max-width:767px){
.rf-swatches__options{grid-template-columns:repeat(2,1fr);gap:6px}
.rf-swatches__swatch{padding:6px;min-height:48px}
.rf-swatches__thumb{width:36px;height:36px;max-width:36px!important;max-height:36px!important}
.rf-swatches__dim{font-size:.625rem}
.rf-swatches__price{font-size:.6875rem}
.rf-swatches__price .woocommerce-Price-amount{font-size:.6875rem}
}

/* Quantity + Add to cart */
.product-actions{display:flex;flex-wrap:wrap;gap:var(--s-3);margin-bottom:var(--s-4)}
.product-actions-variable{margin-bottom:var(--s-4)}
.product-actions-variable .product-actions{margin-bottom:0}
.spx-variations select:focus{outline:none;border-color:var(--c-primary)}
.qty-selector{display:flex;align-items:center;border:1.5px solid var(--c-border);border-radius:var(--radius);overflow:hidden;flex-shrink:0}
.qty-selector button{width:40px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:600;color:var(--c-text-secondary);transition:background var(--dur) var(--ease)}
@media(hover:hover){.qty-selector button:hover{background:var(--c-surface)}}
.qty-selector button:active{background:var(--c-surface)}
.qty-selector input{width:48px;height:44px;text-align:center;font-size:.9375rem;font-weight:600;border-left:1px solid var(--c-border);border-right:1px solid var(--c-border);-moz-appearance:textfield;appearance:textfield}
.qty-selector input::-webkit-outer-spin-button,.qty-selector input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.btn-add-cart{flex:1 1 200px;min-height:52px;padding:var(--s-2) var(--s-4);background:var(--c-primary);color:var(--c-primary-text);border-radius:var(--radius);transition:background var(--dur) var(--ease);display:flex;align-items:center;justify-content:center;gap:var(--s-3);min-width:0}
@media(hover:hover){.btn-add-cart:hover{background:var(--c-primary-hover)}}
.btn-add-cart:active{background:var(--c-primary-hover)}
.btn-add-cart-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.2}
.btn-add-cart-text strong{font-size:1rem;font-weight:600}
.btn-add-cart-text small{font-size:.6875rem;font-weight:400;opacity:.8}

/* Stock urgency */
.spx-stock-urgency{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-2) 0;font-size:.75rem}
.spx-stock-badge{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:var(--c-success,#2b8a3e)}
.spx-stock-dot{width:8px;height:8px;border-radius:50%;background:var(--c-success,#2b8a3e);animation:spx-pulse 2s ease-in-out infinite;flex-shrink:0}
.spx-stock-msg{color:var(--c-text-muted,#adb5bd);font-weight:400}
@keyframes spx-pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes spin{to{transform:rotate(360deg)}}

/* Info badge green icon */
.info-badge-icon-green{color:var(--c-success,#2b8a3e)!important}

/* Trust signals (inline flex-wrap, each item self-contained) */
.trust-signals{display:flex;flex-wrap:wrap;gap:var(--s-2);padding:var(--s-4);background:var(--c-surface);border-radius:var(--radius);margin-bottom:var(--s-4)}
.trust-item-wrap{display:contents}
.trust-item-wrap .trust-content{flex-basis:100%;margin:-2px 0 var(--s-2);padding:var(--s-2) var(--s-3);font-size:.75rem;line-height:1.6;color:var(--c-text-muted);background:var(--c-bg);border-radius:var(--radius-sm);border:1px solid var(--c-border)}
.trust-item-wrap .trust-content p{margin:0}
.trust-signals .trust-item{display:inline-flex;align-items:center;gap:var(--s-1);font-size:.8125rem;font-weight:500;color:var(--c-text-secondary);background:transparent;border:0;cursor:pointer;padding:2px 0;transition:color var(--dur) var(--ease);white-space:nowrap}
@media(hover:hover){.trust-signals .trust-item:hover{color:var(--c-text)}}
.trust-signals .trust-item:active{color:var(--c-text)}
.trust-signals .trust-item svg:first-child{width:18px;height:18px;color:var(--c-success);flex-shrink:0}
.trust-chevron{width:11px;height:11px;flex-shrink:0;color:var(--c-text-muted);transition:transform var(--dur) var(--ease);opacity:.5}
.trust-item[aria-expanded="true"] .trust-chevron{transform:rotate(180deg);opacity:1}

/* Product meta link color */
.product-meta-value a{color:#4a7cad!important;transition:color var(--dur) var(--ease)}
@media(hover:hover){.product-meta-value a:hover{color:#2d5f8a!important}}

/* Product tabs (description, specs) */
.product-tabs{border-top:1px solid var(--c-border);margin-top:var(--s-6)}
.product-tabs-nav{display:flex;overflow-x:auto;scrollbar-width:none}
.product-tabs-nav::-webkit-scrollbar{display:none}
.product-tab-btn{padding:var(--s-3) var(--s-4);font-size:.875rem;font-weight:600;color:var(--c-text-secondary);white-space:nowrap;border-bottom:2px solid transparent;transition:all var(--dur) var(--ease)}
.product-tab-btn.is-active{color:var(--c-primary);border-bottom-color:var(--c-primary)}
.product-tab-panel{display:none;padding:var(--s-4) 0;word-wrap:break-word;overflow-wrap:break-word;overflow-x:auto}
.product-tab-panel.is-active{display:block}
.product-tab-panel p{font-size:.875rem;line-height:1.7;color:var(--c-text-secondary);margin-bottom:var(--s-4)}

/* --- Description Panel - Structured Content --- */
.product-tab-panel[data-panel="description"] h2{font-size:1.05rem;font-weight:700;color:var(--c-text);margin:var(--s-6) 0 var(--s-2) 0;padding-bottom:var(--s-2);border-bottom:2px solid var(--c-primary);display:inline-block}
.product-tab-panel[data-panel="description"] h2:first-child{margin-top:0}
.product-tab-panel[data-panel="description"] h3{font-size:.925rem;font-weight:600;color:var(--c-text);margin:var(--s-5) 0 var(--s-1) 0}
.product-tab-panel[data-panel="description"] p{font-size:.875rem;line-height:1.8;color:var(--c-text-secondary);margin-bottom:var(--s-3)}
.product-tab-panel[data-panel="description"] h3+p{color:var(--c-text-secondary);padding-left:var(--s-4);border-left:3px solid var(--c-surface-hover)}
.product-tab-panel[data-panel="description"] strong{color:var(--c-text);font-weight:700}
@media(min-width:768px){
  .product-tab-panel[data-panel="description"]{max-width:780px}
  .product-tab-panel[data-panel="description"] h2{font-size:1.125rem}
  .product-tab-panel[data-panel="description"] h3{font-size:.975rem}
  .product-tab-panel[data-panel="description"] p{font-size:.9rem}
}

/* ==========================================================================
   RELATED PRODUCTS
   ========================================================================== */
.related-products{margin-top:var(--s-8);padding-top:var(--s-6);border-top:1px solid var(--c-border)}
.section-title{font-size:1.125rem;font-weight:800;margin-bottom:var(--s-4)}

/* ==========================================================================
   PAGINATION
   ========================================================================== */
.pagination{display:flex;align-items:center;justify-content:center;gap:var(--s-2);padding:var(--s-8) 0}
.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 var(--s-3);font-size:.875rem;font-weight:600;border-radius:var(--radius);transition:all var(--dur) var(--ease)}
.pagination a{color:var(--c-text-secondary);border:1px solid var(--c-border)}
@media(hover:hover){.pagination a:hover{border-color:var(--c-primary);color:var(--c-primary)}}
.pagination .current{background:var(--c-primary);color:var(--c-primary-text)}

/* ==========================================================================
   CART DRAWER (slide-in from right)
   ========================================================================== */
.cart-drawer{position:fixed;top:0;left:0;width:100%;height:100%;z-index:200;visibility:hidden;pointer-events:none}
.cart-drawer.is-open{visibility:visible;pointer-events:auto}
.cart-drawer-overlay{position:absolute;inset:0;background:var(--c-overlay);opacity:0;transition:opacity .3s var(--ease)}
.cart-drawer.is-open .cart-drawer-overlay{opacity:1}
.cart-drawer-panel{position:absolute;top:0;right:0;width:90%;max-width:400px;height:100%;background:var(--c-bg);transform:translateX(100%);transition:transform .3s var(--ease);display:flex;flex-direction:column}
.cart-drawer.is-open .cart-drawer-panel{transform:translateX(0)}
.cart-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4);border-bottom:1px solid var(--c-border)}
.cart-drawer-header h3{font-size:1rem;font-weight:700;margin:0}
.cart-drawer-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center}
.cart-drawer-close svg{width:20px;height:20px}
.cart-drawer-items{flex:1;overflow-y:auto;padding:var(--s-4);-webkit-overflow-scrolling:touch}
.cart-drawer-item{display:flex;gap:var(--s-3);padding:var(--s-3) 0;border-bottom:1px solid var(--c-border)}
.cart-drawer-item-img{width:64px;height:64px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;background:var(--c-surface);display:block}
.cart-drawer-item-img img{width:100%;height:100%;object-fit:contain}
.cart-drawer-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--s-1)}
.cart-drawer-item-name{font-size:.8125rem;font-weight:600;line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--c-text);text-decoration:none;transition:color var(--dur) var(--ease)}
@media(hover:hover){a.cart-drawer-item-name:hover{color:var(--c-primary)}}
.cart-drawer-item-price{font-size:.8125rem;color:var(--c-text-secondary);margin:0;font-weight:500}
.cart-drawer-item-actions{display:flex;align-items:center;gap:var(--s-3);margin-top:var(--s-1)}
.cart-drawer-qty{display:flex;align-items:center;border:1px solid var(--c-border);border-radius:var(--radius-sm);overflow:hidden}
.cart-drawer-qty button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600;color:var(--c-text-secondary);background:transparent;border:0;cursor:pointer;transition:background var(--dur) var(--ease)}
@media(hover:hover){.cart-drawer-qty button:hover{background:var(--c-surface)}}
.cart-drawer-qty button:active{background:var(--c-surface)}
.cart-drawer-qty-val{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border-left:1px solid var(--c-border);border-right:1px solid var(--c-border)}
.cart-drawer-remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--c-text-muted);border-radius:var(--radius-sm);transition:all var(--dur) var(--ease);background:transparent;border:0;cursor:pointer;margin-left:auto}
@media(hover:hover){.cart-drawer-remove:hover{color:var(--c-danger);background:var(--c-surface)}}
.cart-drawer-remove:active{color:var(--c-danger);background:var(--c-surface)}
.cart-drawer-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--c-text-muted);font-size:.875rem}
.cart-drawer-footer{padding:var(--s-4);border-top:1px solid var(--c-border);display:flex;flex-direction:column;gap:var(--s-3)}
.cart-drawer-total{display:flex;justify-content:space-between;font-size:.9375rem}
.cart-drawer-total strong{font-weight:600}
.btn-drawer{display:flex;align-items:center;justify-content:center;gap:var(--s-2);height:44px;border-radius:var(--radius);font-size:.875rem;font-weight:500;text-decoration:none;transition:all var(--dur) var(--ease);border:1.5px solid var(--c-border);color:var(--c-text)}
@media(hover:hover){.btn-drawer:hover{border-color:var(--c-primary);color:var(--c-primary)}}
.btn-drawer:active{border-color:var(--c-primary);color:var(--c-primary)}
.btn-drawer.btn-drawer-primary{background:var(--c-primary);color:var(--c-primary-text)!important;border-color:var(--c-primary);font-weight:700}
@media(hover:hover){.btn-drawer.btn-drawer-primary:hover{background:var(--c-primary-hover);border-color:var(--c-primary-hover)}}
.btn-drawer.btn-drawer-primary:active{background:var(--c-primary-hover);border-color:var(--c-primary-hover)}

/* ==========================================================================
   WOOCOMMERCE LOGIN / MY ACCOUNT
   ========================================================================== */
.woocommerce-form-login,.woocommerce-form-register{max-width:420px;margin:var(--s-6) auto;padding:var(--s-6);background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius)}
.woocommerce-form-login h2,.woocommerce-form-register h2,.u-column1 h2,.u-column2 h2{font-size:1.25rem;font-weight:800;margin-bottom:var(--s-4);text-align:center}
.woocommerce-form-row{margin-bottom:var(--s-4)}
.woocommerce-form-row label{display:block;font-size:.8125rem;font-weight:600;color:var(--c-text-secondary);margin-bottom:var(--s-1)}
.woocommerce-form-row label .required{color:var(--c-danger)}
.woocommerce-form-row input[type="text"],
.woocommerce-form-row input[type="email"],
.woocommerce-form-row input[type="password"]{width:100%;height:44px;padding:0 var(--s-4);background:var(--c-surface);border:1.5px solid var(--c-border);border-radius:var(--radius);font-size:.875rem;transition:border-color var(--dur) var(--ease)}
.woocommerce-form-row input:focus{border-color:var(--c-primary);background:var(--c-bg);outline:none}
.woocommerce-form-login__rememberme{display:flex;align-items:center;gap:var(--s-2);font-size:.8125rem;color:var(--c-text-secondary);margin-bottom:var(--s-4)}
.woocommerce-form-login__rememberme input[type="checkbox"]{width:16px;height:16px;accent-color:var(--c-primary)}
.woocommerce-form-login__submit,.woocommerce-form-register button[type="submit"],.woocommerce-Button{display:flex!important;align-items:center;justify-content:center;width:100%;height:44px;padding:0 var(--s-4);background:var(--c-primary)!important;color:var(--c-primary-text)!important;font-size:.9375rem;font-weight:700;border:0;border-radius:var(--radius);cursor:pointer;transition:background var(--dur) var(--ease);margin-top:var(--s-2)}
@media(hover:hover){.woocommerce-form-login__submit:hover,.woocommerce-form-register button[type="submit"]:hover,.woocommerce-Button:hover{background:var(--c-primary-hover)!important}}
.woocommerce-form-login__submit:active,.woocommerce-form-register button[type="submit"]:active,.woocommerce-Button:active{background:var(--c-primary-hover)!important}
.woocommerce-LostPassword{text-align:center;margin-top:var(--s-3)}
.woocommerce-LostPassword a{font-size:.8125rem;color:var(--c-primary);text-decoration:none;transition:color var(--dur) var(--ease)}
@media(hover:hover){.woocommerce-LostPassword a:hover{text-decoration:underline}}

/* My Account navigation */
.woocommerce-MyAccount-navigation{margin-bottom:var(--s-4)}
.woocommerce-MyAccount-navigation ul{display:flex;flex-wrap:wrap;gap:var(--s-2)}
.woocommerce-MyAccount-navigation li{list-style:none}
.woocommerce-MyAccount-navigation li a{display:block;padding:var(--s-2) var(--s-4);font-size:.8125rem;font-weight:600;color:var(--c-text-secondary);background:var(--c-surface);border-radius:var(--radius);transition:all var(--dur) var(--ease)}
.woocommerce-MyAccount-navigation li.is-active a,
@media(hover:hover){.woocommerce-MyAccount-navigation li a:hover{color:var(--c-primary);background:var(--c-surface-hover)}}

/* WooCommerce notices - only show on cart/checkout */
.woocommerce-message,.woocommerce-info{padding:var(--s-3) var(--s-4);border-radius:var(--radius);font-size:.875rem;margin-bottom:var(--s-4)}
.woocommerce-message{background:#e8f5e9;color:var(--c-success);border:1px solid #c8e6c9}
.woocommerce-error{background:#fce4e4;color:var(--c-danger);border:1px solid #f8d7d7;padding:var(--s-3) var(--s-4);border-radius:var(--radius);font-size:.875rem;margin-bottom:var(--s-4)}
.woocommerce-info{background:#e3f2fd;color:#1565c0;border:1px solid #bbdefb}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:var(--c-text);color:rgba(255,255,255,.7);margin-top:var(--s-16)}
.footer-inner{padding:var(--s-8) var(--s-4)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--s-6)}
.footer-col h3{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin-bottom:var(--s-3)}
.footer-logo{display:inline-block;margin-bottom:var(--s-2)}
.footer-logo img{filter:brightness(0) invert(1)}
.footer-col a{display:block;font-size:.8125rem;padding:var(--s-1) 0;transition:color var(--dur) var(--ease)}
@media(hover:hover){.footer-col a:hover{color:var(--c-primary)}}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin:0;padding:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:var(--s-4) 0;font-size:.75rem;text-align:center}
.footer-bottom .container{display:flex;flex-direction:column;align-items:center;gap:var(--s-2)}
.footer-bottom-extra{font-size:.6875rem;color:rgba(255,255,255,.4);line-height:1.6}
.footer-bottom-extra a{color:rgba(255,255,255,.5);text-decoration:underline}
@media(hover:hover){.footer-bottom-extra a:hover{color:var(--c-primary)}}

/* Footer trust: Pagamento & Segurança */
.footer-trust{
    display:flex;align-items:flex-start;justify-content:center;gap:var(--s-10,40px);
    padding:var(--s-5,20px) 0;margin-top:var(--s-6,24px);
    border-top:1px solid rgba(255,255,255,.08);
}
.footer-trust-col{text-align:center}
.footer-trust-col h4{
    font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
    color:rgba(255,255,255,.35);margin:0 0 var(--s-2,8px);
}
.footer-trust-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.footer-badge{
    display:inline-flex;align-items:center;justify-content:center;
    height:28px;padding:0 8px;background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.06);border-radius:4px;
}
.footer-badge img{max-height:16px;width:auto;display:block;filter:brightness(0) invert(1);opacity:.7}
.footer-badge-security{height:32px;padding:0 6px;background:transparent;border:none}
.footer-badge-security img{max-height:28px;filter:none;opacity:.6}
@media(max-width:640px){
    .footer-trust{flex-direction:column;align-items:center;gap:var(--s-5,20px)}
}

/* Cart page */
.woocommerce-cart-form{overflow-x:auto;max-width:100%}
.woocommerce-cart-form table{width:100%;border-collapse:collapse;min-width:500px}
.woocommerce-cart-form th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text-muted);padding:var(--s-3);border-bottom:2px solid var(--c-border);text-align:left}
.woocommerce-cart-form td{padding:var(--s-3);border-bottom:1px solid var(--c-border);font-size:.875rem;vertical-align:middle}

/* ==========================================================================
   RESPONSIVE - Below fold
   ========================================================================== */
@media(min-width:640px){
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}

@media(min-width:1024px){
  .product-info h1{font-size:1.5rem}
  .footer-grid{grid-template-columns:repeat(4,1fr)}
  .mobile-menu{display:none!important}
}

/* Product layout goes 2-col only when there's enough room */
@media(min-width:1200px){
  .single-product-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--s-8)}
}

/* Sticky bar body padding on mobile for single product */
.single-product .site-footer{margin-bottom:80px}
@media(min-width:1024px){
  .single-product .site-footer{margin-bottom:0}
}

/* ==========================================================================
   HERO BLOCK: Carousel + Categories Grid
   ========================================================================== */

.spx-hero-block {
    display:grid;grid-template-columns:70% 1fr;gap:var(--s-3);
    margin-bottom:var(--s-6);height:360px;
}
.spx-hero-block > *{min-width:0;min-height:0}
@media(max-width:1024px){.spx-hero-block{height:300px}}
@media(max-width:768px){.spx-hero-block{height:260px}}
@media(max-width:640px){
    .spx-hero-block{grid-template-columns:1fr;height:auto}
    .spx-hero-cats{display:none}
}

/* Carousel container */
.spx-hero-carousel {
    position:relative;overflow:hidden;border-radius:var(--radius-lg,12px);
    background:var(--c-text);height:100%;
}
@media(max-width:640px){
    .spx-hero-carousel{height:auto;aspect-ratio:16/10}
}
/* Slides */
.spx-hero-slide {
    position:absolute;inset:0;opacity:0;transition:opacity .6s ease;
    display:flex;align-items:stretch;pointer-events:none;
}
.spx-hero-slide.is-active{opacity:1;pointer-events:auto}

/* Image (left) */
.spx-hero-slide-img {
    width:28%;flex-shrink:0;overflow:hidden;
}
.spx-hero-slide-img img {
    width:100%;height:100%;object-fit:contain;object-position:left bottom;display:block;
}
/* Content (right) */
.spx-hero-slide-content {
    flex:1;display:flex;flex-direction:column;justify-content:center;
    padding:var(--s-4) var(--s-5) var(--s-4) var(--s-3);
    gap:var(--s-2);min-width:0;
}

.spx-hero-badge {
    display:inline-flex;align-self:flex-start;
    padding:3px 10px;border-radius:4px;
    font-size:.625rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
    background:var(--c-primary,#ff6b00);color:#fff;
}

.spx-hero-title {
    font-size:clamp(1rem, 2vw, 1.75rem);font-weight:800;color:#fff;line-height:1.2;
    margin:0;letter-spacing:-.01em;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

.spx-hero-desc {
    font-size:.8125rem;color:rgba(255,255,255,.75);line-height:1.5;
    margin:0;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

.spx-hero-price {
    font-size:1.125rem;font-weight:700;color:#fff;
}
.spx-hero-price del{opacity:.5;font-size:.875rem;font-weight:400}
.spx-hero-price ins{text-decoration:none}

.spx-hero-cta {
    display:inline-flex;align-items:center;align-self:flex-start;gap:6px;
    padding:10px 20px;background:#fff;color:var(--c-text,#212529);
    border-radius:var(--radius,8px);font-size:.8125rem;font-weight:700;
    text-decoration:none;transition:all var(--dur) var(--ease);margin-top:var(--s-1);
}
@media(hover:hover){.spx-hero-cta:hover{background:var(--c-primary);color:#fff}}
.spx-hero-cta:active{background:var(--c-primary);color:#fff}

@media(max-width:600px){
    .spx-hero-slide-img{width:32%}
    .spx-hero-slide-content{padding:var(--s-3) var(--s-3) var(--s-3) var(--s-2);gap:4px}
    .spx-hero-cta{padding:8px 14px;font-size:.75rem}
    .spx-hero-desc{font-size:.6875rem;-webkit-line-clamp:2}
}

/* Arrows */
.spx-hero-arrow {
    position:absolute;top:50%;transform:translateY(-50%);z-index:5;
    width:36px;height:36px;border-radius:50%;
    background:rgba(255,255,255,.15);backdrop-filter:blur(4px);
    border:1px solid rgba(255,255,255,.2);color:#fff;
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    opacity:0;transition:all .3s;
}
.spx-hero-arrow svg{width:18px;height:18px}
@media(hover:hover){.spx-hero-carousel:hover .spx-hero-arrow{opacity:1}}
@media(hover:none){.spx-hero-arrow{opacity:1}}
@media(hover:hover){.spx-hero-arrow:hover{background:rgba(255,255,255,.3)}}
.spx-hero-prev{left:12px}
.spx-hero-next{right:12px}

/* Dots */
.spx-hero-dots {
    position:absolute;bottom:12px;left:50%;transform:translateX(-50%);z-index:5;
    display:flex;gap:6px;
}
.spx-hero-dot {
    width:8px;height:8px;border-radius:50%;border:none;cursor:pointer;
    background:rgba(255,255,255,.4);transition:all .3s;padding:0;
}
.spx-hero-dot.is-active{background:#fff;width:20px;border-radius:4px}

/* Categories panel (right) */
.spx-hero-cats {
    background:var(--c-surface,#f8f9fa);border:1px solid var(--c-border,#e9ecef);
    border-radius:var(--radius-lg,12px);padding:var(--s-4);
    display:flex;flex-direction:column;overflow:hidden;height:100%;
}
.spx-hero-cats-title {
    font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
    color:var(--c-text,#212529);margin:0 0 var(--s-3);padding-bottom:var(--s-2);
    border-bottom:2px solid var(--c-primary,#ff6b00);align-self:flex-start;
    flex-shrink:0;
}

.spx-hero-cats-grid {
    display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-3);
    flex:1;align-content:center;
}

.spx-hero-cat-item {
    display:flex;flex-direction:column;align-items:center;gap:var(--s-2);
    text-decoration:none;padding:var(--s-2);border-radius:var(--radius,8px);
    transition:all var(--dur) var(--ease);min-width:0;
}
@media(hover:hover){.spx-hero-cat-item:hover{background:var(--c-bg,#fff);box-shadow:0 2px 8px rgba(0,0,0,.06)}}

.spx-hero-cat-img {
    width:64px;height:64px;border-radius:var(--radius,8px);overflow:hidden;
    background:var(--c-bg,#fff);border:1px solid var(--c-border,#e9ecef);
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.spx-hero-cat-img img{width:100%;height:100%;object-fit:contain;padding:4px}

.spx-hero-cat-name {
    font-size:.75rem;font-weight:600;color:var(--c-text,#212529);
    text-align:center;line-height:1.3;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
@media(hover:hover){.spx-hero-cat-item:hover .spx-hero-cat-name{color:var(--c-primary,#ff6b00)}}

@media(min-width:1100px){
    .spx-hero-cat-img{width:72px;height:72px}
    .spx-hero-cat-name{font-size:.8125rem}
}

/* Tablet: compact */
@media(max-width:899px){
    .spx-hero-cats{padding:var(--s-3)}
    .spx-hero-cats-title{font-size:.6875rem}
    .spx-hero-cat-img{width:52px;height:52px}
    .spx-hero-cat-name{font-size:.6875rem}
    .spx-hero-cats-grid{gap:var(--s-2)}
}

/* ==========================================================================
   PRODUCT CAROUSELS
   ========================================================================== */

.spx-products-section{margin-top:var(--s-6)}

.spx-products-header {
    display:flex;align-items:flex-start;justify-content:space-between;
    margin-bottom:var(--s-4);gap:var(--s-3);
}
.spx-products-nav{display:flex;align-items:center;gap:var(--s-2);flex-shrink:0;margin-top:2px}
.spx-products-link{font-size:.8125rem;font-weight:600;color:var(--c-primary);white-space:nowrap}

/* Arrows (same style as hero) */
.spx-carousel-arrow {
    width:32px;height:32px;border-radius:50%;border:1px solid var(--c-border,#e9ecef);
    background:var(--c-bg,#fff);color:var(--c-text,#212529);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    transition:all var(--dur) var(--ease);flex-shrink:0;
}
.spx-carousel-arrow svg{width:16px;height:16px}
@media(hover:hover){.spx-carousel-arrow:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-surface)}}

/* Scrollable track */
.spx-products-carousel {
    display:flex;gap:var(--s-4);overflow-x:auto;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding-bottom:var(--s-2);
}
.spx-products-carousel::-webkit-scrollbar{display:none}

.spx-carousel-item {
    scroll-snap-align:start;flex-shrink:0;
    width:calc((100% - var(--s-4)) / 2);
}

/* Product card inside carousel needs full height */
.spx-carousel-item .product-card{height:100%}

@media(min-width:640px){
    .spx-carousel-item{width:calc((100% - var(--s-4) * 2) / 3)}
}
@media(min-width:900px){
    .spx-carousel-item{width:calc((100% - var(--s-4) * 3) / 4)}
}
@media(min-width:1280px){
    .spx-carousel-item{width:calc((100% - var(--s-4) * 4) / 5)}
}

/* ==========================================================================
   PRODUCT REVIEWS
   ========================================================================== */

.woocommerce-Reviews{margin-top:var(--s-8)}

/* Title */
.woocommerce-Reviews-title{
    font-size:1.125rem;font-weight:700;color:var(--c-text);
    margin:0 0 var(--s-6);padding-bottom:var(--s-3);
    border-bottom:2px solid var(--c-primary);display:inline-block;
}
.woocommerce-Reviews-title span{font-weight:400;color:var(--c-text-secondary)}

/* Review list */
.woocommerce-Reviews .commentlist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-4)}

/* Single review card */
.woocommerce-Reviews .review{list-style:none;margin:0}
.woocommerce-Reviews .comment_container{
    display:flex;gap:var(--s-4);padding:var(--s-4);
    background:var(--c-surface);border:1px solid var(--c-border);
    border-radius:var(--radius-lg,12px);transition:border-color .2s ease;
}
@media(hover:hover){.woocommerce-Reviews .comment_container:hover{border-color:rgba(0,0,0,.12)}}

/* Avatar */
.woocommerce-Reviews .avatar{
    width:44px;height:44px;border-radius:50%;flex-shrink:0;
    border:2px solid var(--c-border);object-fit:cover;
}

/* Comment text wrapper */
.woocommerce-Reviews .comment-text{flex:1;min-width:0}

/* Stars */
.woocommerce-Reviews .star-rating{
    display:inline-flex;font-size:.8125rem;color:var(--c-star,#f59f00);
    margin-bottom:var(--s-1);overflow:hidden;position:relative;
    width:5.4em;height:1.2em;line-height:1.2;
}
.woocommerce-Reviews .star-rating::before{
    content:'★★★★★';letter-spacing:2px;color:var(--c-border,#e9ecef);
}
.woocommerce-Reviews .star-rating span{
    position:absolute;top:0;left:0;overflow:hidden;white-space:nowrap;height:100%;
}
.woocommerce-Reviews .star-rating span::before{
    content:'★★★★★';letter-spacing:2px;color:var(--c-star,#f59f00);
}
.woocommerce-Reviews .star-rating .rating,
.woocommerce-Reviews .star-rating span{font-size:0;color:transparent}
.woocommerce-Reviews .star-rating span::before{font-size:.8125rem}

/* Meta: author + date */
.woocommerce-Reviews .meta{
    margin:0 0 var(--s-2);display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap;
}
.woocommerce-Reviews .woocommerce-review__author{
    font-size:.875rem;font-weight:600;color:var(--c-text);
}
.woocommerce-Reviews .woocommerce-review__dash{display:none}
.woocommerce-Reviews .woocommerce-review__published-date{
    font-size:.75rem;color:var(--c-text-muted);
}

/* Review text */
.woocommerce-Reviews .description p{
    font-size:.8125rem;line-height:1.6;color:var(--c-text-secondary);margin:0;
}

/* Translate button (plugin: spx-translate-reviews) */
.spx-tr-btn{
    display:inline-flex;align-items:center;gap:6px;
    padding:4px 12px;border:1.5px solid var(--c-border);border-radius:20px;
    background:var(--c-bg);font-size:.6875rem;font-weight:600;
    color:var(--c-text-secondary);cursor:pointer;margin-bottom:var(--s-2);
    transition:all .2s ease;font-family:inherit;
}
@media(hover:hover){.spx-tr-btn:hover{border-color:var(--c-primary);color:var(--c-primary)}}
.spx-tr-btn:active{border-color:var(--c-primary);color:var(--c-primary)}
.spx-tr-btn:active{background:var(--c-surface)}
.spx-tr-btn[disabled]{opacity:.5;cursor:wait}
.spx-tr-btn.is-loading .spx-tr-label{display:inline-flex;align-items:center;gap:6px}
.spx-tr-btn.is-loading .spx-tr-label::after{
    content:'';display:inline-block;width:10px;height:10px;
    border:1.5px solid var(--c-border);border-top-color:var(--c-primary);
    border-radius:50%;animation:spin .6s linear infinite;
}
.spx-tr-btn.is-translated{border-color:var(--c-primary);color:var(--c-primary);background:rgba(255,107,0,.04)}
.spx-tr-flag{width:14px;height:14px;flex-shrink:0}

/* Mobile: stack avatar */
@media(max-width:600px){
    .woocommerce-Reviews .comment_container{gap:var(--s-3);padding:var(--s-3)}
    .woocommerce-Reviews .avatar{width:36px;height:36px}
}

/* ── Review Form ── */
#review_form_wrapper{margin-top:var(--s-6)}
#review_form .comment-reply-title{
    font-size:1rem;font-weight:700;color:var(--c-text);
    margin:0 0 var(--s-4);display:block;
}
#review_form .comment-reply-title small a{
    font-size:.75rem;font-weight:400;color:var(--c-primary);text-decoration:none;margin-left:var(--s-2);
}

#review_form .comment-notes{
    font-size:.75rem;color:var(--c-text-muted);margin:0 0 var(--s-4);
}

/* Rating select */
#review_form .comment-form-rating{margin-bottom:var(--s-4)}
#review_form .comment-form-rating label{
    display:block;font-size:.8125rem;font-weight:600;color:var(--c-text);margin-bottom:var(--s-1);
}
#review_form #rating{
    padding:var(--s-2) var(--s-3);border:1.5px solid var(--c-border);border-radius:var(--radius);
    font-size:.875rem;font-family:inherit;background:var(--c-bg);color:var(--c-text);
    transition:border-color .2s;cursor:pointer;
}
#review_form #rating:focus{outline:none;border-color:var(--c-primary)}

/* Form fields */
#review_form .comment-form label{
    display:block;font-size:.8125rem;font-weight:600;color:var(--c-text);margin-bottom:4px;
}
#review_form .comment-form .required{color:var(--c-danger)}

#review_form .comment-form textarea,
#review_form .comment-form input[type="text"],
#review_form .comment-form input[type="email"]{
    width:100%;padding:var(--s-3);border:1.5px solid var(--c-border);border-radius:var(--radius);
    font-size:.875rem;font-family:inherit;background:var(--c-bg);color:var(--c-text);
    transition:border-color .2s;
}
#review_form .comment-form textarea{min-height:100px;resize:vertical}
#review_form .comment-form textarea:focus,
#review_form .comment-form input[type="text"]:focus,
#review_form .comment-form input[type="email"]:focus{outline:none;border-color:var(--c-primary)}

#review_form .comment-form p{margin:0 0 var(--s-3)}

/* Author + email side by side on desktop */
@media(min-width:640px){
    #review_form .comment-form-author,
    #review_form .comment-form-email{display:inline-block;width:calc(50% - 6px);vertical-align:top}
    #review_form .comment-form-author{margin-right:12px}
}

/* Cookies consent */
#review_form .comment-form-cookies-consent{
    display:flex;align-items:flex-start;gap:var(--s-2);
    font-size:.75rem;color:var(--c-text-muted);
}
#review_form .comment-form-cookies-consent input{margin-top:2px;accent-color:var(--c-primary)}

/* Submit button */
#review_form .form-submit{margin-top:var(--s-4)}
#review_form .form-submit .submit{
    display:inline-flex;align-items:center;justify-content:center;
    padding:var(--s-3) var(--s-6);background:var(--c-primary);color:#fff;
    border:none;border-radius:var(--radius);font-size:.875rem;font-weight:700;
    font-family:inherit;cursor:pointer;transition:background .2s ease;
}
@media(hover:hover){#review_form .form-submit .submit:hover{background:var(--c-primary-hover)}}
#review_form .form-submit .submit:active{background:var(--c-primary-hover)}

/* ==========================================================================
   PRODUCT SECTION FILTER TABS + PARENT BADGE
   ========================================================================== */

/* Header left: stacks title + filters */
.spx-products-header-left{display:flex;flex-direction:column;gap:var(--s-2,8px);min-width:0;flex:1}

/* Filter tabs row — inside a scroll wrapper that shows a fade edge */
.spx-filter-scroll{
    position:relative;
    min-width:0;          /* allow flex child to shrink */
}
/* Right-edge gradient: shows when there are more tabs off-screen */
.spx-filter-scroll::after{
    content:'';
    position:absolute;right:0;top:0;bottom:2px; /* 2px = tab padding-bottom */
    width:56px;
    background:linear-gradient(to right, transparent, var(--c-bg,#fff));
    pointer-events:none;
    transition:opacity .25s ease;
}
/* Gradient fades out once the user has scrolled to the last tab */
.spx-filter-scroll.is-end::after{ opacity:0 }

.spx-filter-tabs{
    display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;
    -webkit-overflow-scrolling:touch;padding-bottom:2px;
    padding-right:48px; /* breathing room before the fade gradient */
}
.spx-filter-tabs::-webkit-scrollbar{display:none}

.spx-filter-tab{
    flex-shrink:0;padding:6px 14px;border:1.5px solid var(--c-border,#e9ecef);
    border-radius:20px;background:var(--c-bg,#fff);
    font-family:inherit;font-size:.75rem;font-weight:600;
    color:var(--c-text-secondary,#6c757d);cursor:pointer;
    transition:all .2s;white-space:nowrap;
}
@media(hover:hover){.spx-filter-tab:hover{border-color:var(--c-primary,#ff6b00);color:var(--c-primary,#ff6b00)}}
.spx-filter-tab:active{border-color:var(--c-primary,#ff6b00);color:var(--c-primary,#ff6b00)}
.spx-filter-tab.is-active{
    background:var(--c-primary,#ff6b00);border-color:var(--c-primary,#ff6b00);
    color:#fff;
}

/* Parent badge (child sections) */
.spx-section-parent-badge{
    display:inline-flex;align-self:flex-start;
    padding:3px 12px;border:1.5px solid var(--c-text,#212529);border-radius:20px;
    font-size:.6875rem;font-weight:700;color:var(--c-text,#212529);
    text-transform:uppercase;letter-spacing:.04em;
}

/* Infinite scroll uses inline styles in templates — no external CSS needed */


/* Product page notices and official WooCommerce variation form compatibility */
.shopex-product-notices{margin-bottom:var(--s-4)}
.shopex-product-notices:empty{display:none}
.product-actions-variable form.variations_form{max-width:100%;display:block;margin:0}
.product-actions-variable table.variations{width:100%;border:0;margin:0 0 var(--s-4);display:block}
.product-actions-variable table.variations tbody,
.product-actions-variable table.variations tr,
.product-actions-variable table.variations th,
.product-actions-variable table.variations td{display:block;width:100%;border:0;padding:0;text-align:left}
.product-actions-variable table.variations tr{margin-bottom:var(--s-3)}
.product-actions-variable table.variations label{display:block;font-size:.8125rem;font-weight:600;color:var(--c-text);margin-bottom:var(--s-1)}
.product-actions-variable table.variations select{width:100%;height:44px;padding:0 var(--s-3);border:1.5px solid var(--c-border);border-radius:var(--radius);font-size:.875rem;font-family:inherit;background:var(--c-bg);color:var(--c-text);cursor:pointer}
.product-actions-variable .reset_variations{display:inline-block;margin-top:var(--s-2);font-size:.8125rem;color:var(--c-primary);text-decoration:none}
.product-actions-variable .single_variation_wrap{width:100%}
.product-actions-variable .woocommerce-variation{margin-bottom:var(--s-3)}
.product-actions-variable .woocommerce-variation-add-to-cart{display:flex;gap:var(--s-3);flex-wrap:wrap;align-items:center}
.product-actions-variable .single_add_to_cart_button{display:flex;align-items:center;justify-content:center;gap:var(--s-2);height:52px;padding:0 var(--s-6);background:var(--c-primary);color:var(--c-primary-text);border:0;border-radius:var(--radius);font-weight:700;cursor:pointer;transition:background var(--dur) var(--ease);flex:1;min-width:220px}
.product-actions-variable .single_add_to_cart_button:hover{background:var(--c-primary-hover)}
.product-actions-variable .single_add_to_cart_button.disabled,
.product-actions-variable .single_add_to_cart_button.wc-variation-selection-needed{opacity:.55;cursor:not-allowed}
.btn-cart.has-error,.sticky-buy-btn.has-error{background:var(--c-danger)!important}

/* Shopex tap/navigation hardening: hidden overlays must never intercept mobile taps */
.mobile-menu:not(.is-open),.cart-drawer:not(.is-open),.spx-overlay:not(.is-open),.spx-checkout-overlay:not(.is-active),.spx-lightbox:not(.is-open){pointer-events:none!important}
.mobile-menu.is-open,.cart-drawer.is-open,.spx-overlay.is-open,.spx-checkout-overlay.is-active,.spx-lightbox.is-open{pointer-events:auto}
@media(hover:none),(pointer:coarse){
  .spx-sort-select-wrap:hover{border-color:var(--c-border,#e9ecef)!important}
  .spx-pill:hover{border-color:var(--c-border,#e9ecef)!important;color:var(--c-text,#212529)!important}
  .spx-pills-arrow:hover svg{color:var(--c-text-secondary,#6c757d)!important}
  .spx-brand-toggle:hover{border-color:var(--c-border,#e9ecef)!important}
  .spx-clear-all:hover{color:var(--c-text-muted,#adb5bd)!important}
  .product-actions-variable .single_add_to_cart_button:hover{background:var(--c-primary,#ff6b00)!important}
}
