/*
Theme Name:  Streetwear Headless
Theme URI:   https://github.com/tu-marca/streetwear-theme
Author:      Tu Marca
Author URI:  https://tu-marca.com
Description: Tema ultra-minimalista para marca de ropa Streetwear. Headless-ready, Mobile-First, con conversión dólar blue automática y soporte completo de WooCommerce.
Version:     1.0.0
Requires at least: 6.3
Tested up to: 6.5
Requires PHP: 8.1
License:     GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: streetwear
Tags:        woocommerce, minimal, dark-mode, headless, streetwear
*/

/* =========================================================
   0. DESIGN TOKENS & CUSTOM PROPERTIES
   ========================================================= */
:root {
  /* Colors */
  --clr-bg:          #0A0A0A;
  --clr-surface:     #141414;
  --clr-border:      #2A2A2A;
  --clr-text:        #F5F5F0;
  --clr-text-muted:  #888880;
  --clr-accent:      #F7C31E;
  --clr-accent-inv:  #0A0A0A;
  --clr-price-main:  #F7C31E;
  --clr-price-ref:   #888880;
  --clr-error:       #D32F2F;
  --clr-success:     #1B5E20;

  /* Typography */
  --font-sans:   'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-mono:   'JetBrains Mono', 'Courier New', monospace;

  --fs-xs:    0.6875rem;   /* 11px */
  --fs-sm:    0.8125rem;   /* 13px */
  --fs-base:  1rem;        /* 16px */
  --fs-md:    1.125rem;    /* 18px */
  --fs-lg:    1.375rem;    /* 22px */
  --fs-xl:    1.75rem;     /* 28px */
  --fs-2xl:   2.25rem;     /* 36px */
  --fs-3xl:   3rem;        /* 48px */

  --fw-light:   300;
  --fw-normal:  400;
  --fw-medium:  500;
  --fw-bold:    700;
  --fw-black:   900;

  --lh-tight:   1.1;
  --lh-snug:    1.3;
  --lh-base:    1.6;

  --ls-tight:  -0.03em;
  --ls-wide:    0.12em;
  --ls-wider:   0.18em;

  /* Spacing */
  --sp-1:   4px;
  --sp-2:   8px;
  --sp-3:   12px;
  --sp-4:   16px;
  --sp-5:   20px;
  --sp-6:   24px;
  --sp-8:   32px;
  --sp-10:  40px;
  --sp-12:  48px;
  --sp-16:  64px;
  --sp-20:  80px;
  --sp-24:  96px;
  --sp-32:  128px;

  /* Layout */
  --container-max:  1280px;
  --container-pad:  var(--sp-6);
  --grid-gap:       var(--sp-6);

  /* UI */
  --radius-sm:  2px;
  --radius-md:  4px;
  --radius-lg:  8px;
  --transition: 220ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
  --shadow-md:  0 4px 16px rgba(0,0,0,.12);
  --shadow-lg:  0 8px 32px rgba(0,0,0,.16);
}

/* Dark Mode */
[data-theme="dark"] {
  --clr-bg:         #111100;
  --clr-surface:    #1A1A00;
  --clr-border:     #333320;
  --clr-text:       #F5F5F0;
  --clr-text-muted: #999988;
  --clr-accent:     #F7C31E;
  --clr-accent-inv: #0A0A0A;
}

/* =========================================================
   1. RESET & BASE
   ========================================================= */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-normal);
  line-height: var(--lh-base);
  color: var(--clr-text);
  background-color: var(--clr-bg);
  transition: background-color var(--transition), color var(--transition);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
ul, ol { list-style: none; }

/* =========================================================
   2. LAYOUT UTILITIES
   ========================================================= */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  box-sizing: border-box;
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
}

/* =========================================================
   3. HEADER
   ========================================================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: var(--clr-bg);
  border-bottom: 1px solid var(--clr-border);
  transition: background-color var(--transition);
}

.site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 56px;
  gap: var(--sp-4);
}

@media (min-width: 768px) {
  .site-header__inner { height: 64px; }
}

/* Logo */
.site-logo {
  font-size: var(--fs-md);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-text);
  justify-self: start;
  white-space: nowrap;
}

/* Nav */
.site-nav {
  display: none;
}

@media (min-width: 1024px) {
  .site-nav {
    display: flex;
    align-items: center;
    gap: var(--sp-8);
  }

  .site-nav a {
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    color: var(--clr-text-muted);
    transition: color var(--transition);
    position: relative;
  }

  .site-nav a::after {
    content: '';
    position: absolute;
    bottom: -2px; left: 0;
    width: 0; height: 1px;
    background: var(--clr-accent);
    transition: width var(--transition);
  }

  .site-nav a:hover,
  .site-nav a.current-menu-item {
    color: var(--clr-text);
  }

  .site-nav a:hover::after,
  .site-nav a.current-menu-item::after {
    width: 100%;
  }
}

/* Header Actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  justify-self: end;
}

.header-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--clr-text);
  border-radius: var(--radius-sm);
  transition: background var(--transition);
}

.header-btn:hover {
  background: var(--clr-surface);
}

/* Theme Toggle */
.theme-toggle {
  position: relative;
  width: 44px; height: 24px;
  background: var(--clr-border);
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: background var(--transition);
  overflow: hidden;
}

.theme-toggle::after {
  content: '';
  position: absolute;
  top: 2px; left: 2px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--clr-accent);
  transition: transform var(--transition);
}

[data-theme="dark"] .theme-toggle { background: var(--clr-text-muted); }
[data-theme="dark"] .theme-toggle::after { transform: translateX(20px); }

/* Cart Icon Badge */
.cart-icon-wrapper {
  position: relative;
}

.cart-count {
  position: absolute;
  top: -4px; right: -6px;
  min-width: 18px; height: 18px;
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  font-size: 10px;
  font-weight: var(--fw-bold);
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
}

/* Mobile Menu Button */
.hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  background: none;
  border: none;
  cursor: pointer;
}

.hamburger span {
  display: block;
  width: 22px; height: 1.5px;
  background: var(--clr-text);
  transition: transform var(--transition), opacity var(--transition);
}

.hamburger.is-active span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger.is-active span:nth-child(2) { opacity: 0; }
.hamburger.is-active span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (min-width: 1024px) {
  .hamburger { display: none; }
}

/* Mobile Nav Drawer */
.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--clr-bg);
  display: flex;
  flex-direction: column;
  padding: var(--sp-6);
  transform: translateX(-100%);
  transition: transform 300ms ease;
}

.mobile-nav.is-open { transform: translateX(0); }

.mobile-nav__close {
  align-self: flex-end;
  background: none; border: none;
  font-size: var(--fs-xl);
  cursor: pointer;
  color: var(--clr-text);
  margin-bottom: var(--sp-8);
}

.mobile-nav ul {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

.mobile-nav a {
  font-size: var(--fs-xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  text-transform: uppercase;
  color: var(--clr-text);
}

/* Dollar Rate Banner */
.dollar-banner {
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  text-align: center;
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* =========================================================
   4. FOOTER
   ========================================================= */
.site-footer {
  margin-top: var(--sp-24);
  border-top: 1px solid var(--clr-border);
  padding: var(--sp-16) 0 var(--sp-8);
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-10);
}

@media (min-width: 768px) {
  .site-footer__grid {
    grid-template-columns: 2fr 1fr 1fr;
  }
}

.footer-brand .site-logo {
  display: block;
  margin-bottom: var(--sp-4);
}

.footer-brand p {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  max-width: 280px;
  line-height: var(--lh-base);
}

.footer-col h4 {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  margin-bottom: var(--sp-5);
  color: var(--clr-text);
}

.footer-col ul {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.footer-col a {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  transition: color var(--transition);
}

.footer-col a:hover { color: var(--clr-text); }

.footer-bottom {
  margin-top: var(--sp-12);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-4);
}

.footer-bottom p {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  letter-spacing: 0.02em;
}

/* =========================================================
   5. PRICE COMPONENT (Dual Currency)
   ========================================================= */
.price-dual {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.price-dual__ars {
  font-size: var(--fs-xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  color: var(--clr-price-main);
  line-height: 1;
}

.price-dual__ars .currency {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  margin-right: var(--sp-1);
}

.price-dual__usd {
  font-size: var(--fs-sm);
  color: var(--clr-price-ref);
  font-weight: var(--fw-normal);
  font-family: var(--font-mono);
}

.price-dual__usd::before { content: 'USD '; }

/* WooCommerce price overrides */
.woocommerce .price,
.woocommerce-Price-amount {
  font-family: var(--font-sans);
}

/* =========================================================
   6. PRODUCT CARD (Archive)
   ========================================================= */
.products-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
  width: 100%;
}

@media (min-width: 640px) {
  .products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
  }
}

@media (min-width: 900px) {
  .products-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
  }
}

@media (min-width: 1200px) {
  .products-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
  }
}


.product-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  cursor: pointer;
  height: auto !important;
  align-self: start;
}

/* Image Container with Hover Swap */
.product-card__image-wrap {
  position: relative;
  height: 280px !important;
  overflow: hidden !important;
  background: var(--clr-surface);
  flex-shrink: 0;
  aspect-ratio: unset !important;   /* anular cualquier aspect-ratio de WC */
}

@media (min-width: 1024px) { .product-card__image-wrap { height: 320px !important; } }
@media (min-width: 1280px) { .product-card__image-wrap { height: 360px !important; } }

.product-card__img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: opacity 400ms ease, transform 600ms ease;
}

.product-card__img--primary   { opacity: 1;  z-index: 1; }
.product-card__img--secondary { opacity: 0;  z-index: 2; }

.product-card:hover .product-card__img--primary   { opacity: 0; }
.product-card:hover .product-card__img--secondary { opacity: 1; }
.product-card:hover .product-card__img--primary   { transform: scale(1.04); }

/* Badge */
.product-card__badge {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  z-index: 3;
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  padding: var(--sp-1) var(--sp-2);
}

/* Quick Add */
.product-card__quick-add {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 4;
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  border: none;
  padding: var(--sp-3);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  cursor: pointer;
  transform: translateY(100%);
  transition: transform var(--transition);
}

.product-card:hover .product-card__quick-add {
  transform: translateY(0);
}

/* Card Info */
.product-card__info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: 0 var(--sp-1);
}

.product-card__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--clr-text);
  line-height: var(--lh-snug);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.product-card__price .price-dual__ars {
  font-size: var(--fs-md);
}

/* =========================================================
   7. SINGLE PRODUCT PAGE
   ========================================================= */
.single-product__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
  padding-block: var(--sp-8);
}

@media (min-width: 768px) {
  .single-product__layout {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-12);
    align-items: start;
  }
}

@media (min-width: 1024px) {
  .single-product__layout {
    grid-template-columns: 52% 1fr;   /* galería 52%, info 48% */
    gap: var(--sp-12);
    align-items: start;
  }
}

/* Gallery */
.product-gallery {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  position: sticky;
  top: calc(64px + var(--sp-6));
}

@media (max-width: 767px) {
  .product-gallery { position: static; }
  .product-gallery__main {
    height: 360px;
  }
}

.product-gallery__main {
  width: 100%;
  height: 500px;           /* altura fija, misma en todos los productos */
  overflow: hidden;
  background: var(--clr-surface);
  cursor: zoom-in;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 1024px) { .product-gallery__main { height: 560px; } }
@media (min-width: 1280px) { .product-gallery__main { height: 620px; } }

.product-gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: contain;   /* muestra la foto completa sin recortar */
  object-position: center;
  transition: transform 400ms ease;
}

.product-gallery__main:hover img {
  transform: scale(1.04);
}

.product-gallery__thumbs {
  display: flex;
  gap: var(--sp-2);
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.product-gallery__thumbs::-webkit-scrollbar { display: none; }

.product-gallery__thumb {
  flex-shrink: 0;
  width: 64px; height: 80px;
  overflow: hidden;
  background: var(--clr-surface);
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: border-color var(--transition);
}

.product-gallery__thumb.is-active,
.product-gallery__thumb:hover {
  border-color: var(--clr-accent);
}

.product-gallery__thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
}

/* Product Info Panel */
.product-info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}

.product-info__category {
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-text-muted);
}

.product-info__title {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  text-transform: uppercase;
  line-height: var(--lh-tight);
  color: var(--clr-text);
}

@media (min-width: 1024px) {
  .product-info__title { font-size: var(--fs-3xl); }
}

.product-info__price-wrap {
  padding: var(--sp-5) 0;
  border-top: 1px solid var(--clr-border);
  border-bottom: 1px solid var(--clr-border);
}

.product-info__price-wrap .price-dual__ars {
  font-size: var(--fs-2xl);
}

/* Size Selector */
.size-selector__label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
}

.size-selector__label span {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}

.size-guide-link {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  letter-spacing: 0.02em;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
}

.size-options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}

.size-option {
  min-width: 44px; height: 44px;
  padding: 0 var(--sp-3);
  border: 1.5px solid var(--clr-border);
  background: transparent;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  cursor: pointer;
  color: var(--clr-text);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.size-option:hover {
  border-color: var(--clr-accent);
}

.size-option.is-selected {
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  border-color: var(--clr-accent);
}

.size-option:disabled,
.size-option.is-out-of-stock {
  opacity: 0.35;
  cursor: not-allowed;
  text-decoration: line-through;
}

/* Add to Cart Button */
.btn-atc {
  width: 100%;
  height: 54px;
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  border: none;
  font-size: var(--fs-xs);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  transition: opacity var(--transition), transform 100ms ease;
  margin-top: var(--sp-2);
}

.btn-atc:hover  { opacity: 0.88; }
.btn-atc:active { transform: scale(0.99); }

.btn-atc:disabled {
  background: var(--clr-border);
  color: var(--clr-text-muted);
  cursor: not-allowed;
}

.btn-atc.is-loading {
  pointer-events: none;
}

.btn-atc .spinner {
  width: 16px; height: 16px;
  border: 2px solid var(--clr-accent-inv);
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 600ms linear infinite;
  display: none;
}

.btn-atc.is-loading .spinner { display: block; }
.btn-atc.is-loading .btn-atc__label { opacity: 0; }

@keyframes spin { to { transform: rotate(360deg); } }

/* Product Description */
.product-description {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-base);
}

.product-description p + p { margin-top: var(--sp-3); }

/* Product Details Accordion */
.product-details { border-top: 1px solid var(--clr-border); }

.accordion-item { border-bottom: 1px solid var(--clr-border); }

.accordion-trigger {
  width: 100%;
  background: none;
  border: none;
  padding: var(--sp-4) 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  color: var(--clr-text);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}

.accordion-icon {
  width: 16px; height: 16px;
  position: relative;
  flex-shrink: 0;
}

.accordion-icon::before,
.accordion-icon::after {
  content: '';
  position: absolute;
  background: var(--clr-text);
  border-radius: 1px;
}

.accordion-icon::before { width: 16px; height: 1.5px; top: 50%; left: 0; transform: translateY(-50%); }
.accordion-icon::after  { width: 1.5px; height: 16px; top: 0; left: 50%; transform: translateX(-50%); transition: transform var(--transition), opacity var(--transition); }

.accordion-item.is-open .accordion-icon::after {
  transform: translateX(-50%) rotate(90deg);
  opacity: 0;
}

.accordion-body {
  overflow: hidden;
  max-height: 0;
  transition: max-height 300ms ease, padding 300ms ease;
}

.accordion-item.is-open .accordion-body {
  max-height: 400px;
  padding-bottom: var(--sp-5);
}

.accordion-body p, .accordion-body li {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-base);
}

/* =========================================================
   8. HOMEPAGE – FEATURED PRODUCTS
   ========================================================= */
.section-hero {
  padding-block: var(--sp-24) var(--sp-16);
  text-align: center;
}

.section-hero__eyebrow {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-4);
}

.section-hero__title {
  font-size: clamp(3rem, 10vw, 7rem);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  text-transform: uppercase;
  line-height: var(--lh-tight);
  color: var(--clr-text);
}

.section-hero__sub {
  margin-top: var(--sp-5);
  font-size: var(--fs-md);
  color: var(--clr-text-muted);
  max-width: 400px;
  margin-inline: auto;
}

.section-hero__cta {
  margin-top: var(--sp-8);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  padding: var(--sp-4) var(--sp-10);
  font-size: var(--fs-xs);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  transition: opacity var(--transition);
}

.section-hero__cta:hover { opacity: 0.8; }

.section {
  padding-block: var(--sp-16);
}

.section__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--sp-10);
  gap: var(--sp-4);
}

.section__title {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  text-transform: uppercase;
  line-height: var(--lh-tight);
}

.section__link {
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-text-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
  white-space: nowrap;
  transition: color var(--transition);
}

.section__link:hover { color: var(--clr-text); }

/* =========================================================
   9. WOOCOMMERCE OVERRIDES
   ========================================================= */
.woocommerce-notices-wrapper { margin-bottom: var(--sp-6); }

.woocommerce-message,
.woocommerce-info {
  background: var(--clr-surface);
  border-top: 3px solid var(--clr-accent);
  color: var(--clr-text);
  font-size: var(--fs-sm);
  padding: var(--sp-4) var(--sp-5);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.woocommerce-error {
  background: #FFF5F5;
  border-left: 3px solid var(--clr-error);
  padding: var(--sp-4) var(--sp-5);
  font-size: var(--fs-sm);
  color: var(--clr-error);
}

/* Cart & Checkout buttons */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--clr-accent) !important;
  color: var(--clr-accent-inv) !important;
  border: none !important;
  border-radius: 0 !important;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  padding: var(--sp-3) var(--sp-6);
  transition: opacity var(--transition) !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover { opacity: 0.85 !important; }

/* Form fields */
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce textarea,
.woocommerce select {
  border: 1.5px solid var(--clr-border) !important;
  border-radius: 0 !important;
  background: var(--clr-bg) !important;
  color: var(--clr-text) !important;
  font-size: var(--fs-sm) !important;
  padding: var(--sp-3) var(--sp-4) !important;
  transition: border-color var(--transition) !important;
}

.woocommerce input:focus,
.woocommerce textarea:focus,
.woocommerce select:focus {
  outline: none !important;
  border-color: var(--clr-accent) !important;
  box-shadow: none !important;
}

/* =========================================================
   10. CART SIDEBAR (Mini-Cart)
   ========================================================= */
.cart-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 300;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition), visibility var(--transition);
}

.cart-drawer-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.cart-drawer {
  position: fixed;
  top: 0; right: 0;
  width: min(420px, 100vw);
  height: 100vh;
  background: var(--clr-bg);
  z-index: 301;
  transform: translateX(100%);
  transition: transform 300ms ease;
  display: flex;
  flex-direction: column;
}

.cart-drawer.is-open { transform: translateX(0); }

.cart-drawer__head {
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cart-drawer__title {
  font-size: var(--fs-xs);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}

.cart-drawer__close {
  background: none; border: none;
  cursor: pointer; color: var(--clr-text);
  padding: var(--sp-2);
}

.cart-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-5) var(--sp-6);
}

.cart-drawer__foot {
  padding: var(--sp-5) var(--sp-6);
  border-top: 1px solid var(--clr-border);
}

.cart-drawer__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
}

.cart-drawer__total-amount { font-weight: var(--fw-black); }

.cart-drawer__actions {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 10px;
  position: relative;
  z-index: 10;
}

.btn-view-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  border: 1.5px solid var(--clr-border);
  color: var(--clr-text);
  background: transparent;
  cursor: pointer;
  text-align: center;
  transition: border-color 180ms ease, color 180ms ease;
}
.btn-view-cart:hover { border-color: var(--clr-text); }

.btn-checkout {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clr-accent);
  color: var(--clr-accent-inv);
  text-align: center;
  padding: var(--sp-4);
  font-size: var(--fs-xs);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: opacity 180ms ease;
  position: relative;
  z-index: 10;
  pointer-events: auto !important;
  text-decoration: none;
}
.btn-checkout:hover { opacity: 0.88; }

/* =========================================================
   11. ARCHIVE EXTRAS
   ========================================================= */
.archive-header {
  padding-block: var(--sp-12) var(--sp-8);
  border-bottom: 1px solid var(--clr-border);
  margin-bottom: var(--sp-10);
}

.archive-header__title {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  text-transform: uppercase;
  line-height: var(--lh-tight);
}

.archive-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-8);
  gap: var(--sp-4);
}

.archive-count {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  letter-spacing: 0.02em;
}

.archive-sort select {
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  background: transparent;
  border: none;
  color: var(--clr-text);
  cursor: pointer;
  appearance: none;
  padding-right: var(--sp-4);
}

/* =========================================================
   12. UTILITY CLASSES
   ========================================================= */
.text-center { text-align: center; }
.text-muted   { color: var(--clr-text-muted); }
.uppercase    { text-transform: uppercase; }
.bold         { font-weight: var(--fw-bold); }
.mt-auto      { margin-top: auto; }
.w-full       { width: 100%; }
.hidden       { display: none; }
.sr-only      { @extend .visually-hidden; }

/* Loading skeleton */
.skeleton {
  background: linear-gradient(90deg, var(--clr-surface) 25%, var(--clr-border) 50%, var(--clr-surface) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
}

@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Scroll Reveal ──────────────────────────────────────────── */
.reveal {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 550ms ease, transform 550ms cubic-bezier(.25,.46,.45,.94);
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* product-card usa cardFadeUp propio — no bloquear con reveal */
.product-card.reveal,
.products-grid .product-card {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
}

/* =========================================================
   13. RESPONSIVE HELPERS
   ========================================================= */
@media (max-width: 767px) {
  :root {
    --container-pad: var(--sp-4);
    --grid-gap: var(--sp-3);
  }

  .product-info__title { font-size: var(--fs-xl); }
}

@media (min-width: 1280px) {
  :root {
    --container-pad: var(--sp-10);
  }
}

/* =========================================================
   CAT NAV BAR
   ========================================================= */
.cat-nav {
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-bg);
  position: sticky;
  top: 56px;
  z-index: 90;
  transition: background var(--transition);
}
@media (min-width: 768px) { .cat-nav { top: 64px; } }

.cat-nav__inner {
  display: flex;
  align-items: center;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.cat-nav__inner::-webkit-scrollbar { display: none; }

.cat-nav__link {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 12px 18px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  border-bottom: 2px solid transparent;
  transition: color var(--transition), border-color var(--transition);
  white-space: nowrap;
  margin-bottom: -1px;
}
.cat-nav__link:hover { color: var(--clr-text); }
.cat-nav__link.is-active {
  color: var(--clr-text);
  border-bottom-color: var(--clr-accent);
  font-weight: 700;
}
.cat-nav__icon { font-size: 15px; line-height: 1; }

/* Category hero (con thumbnail de categoría) */
.cat-hero {
  position: relative;
  height: 200px;
  background: var(--clr-surface);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 768px) { .cat-hero { height: 280px; } }

.cat-hero__img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 30%;
}
.cat-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.6) 0%, transparent 65%);
}
.cat-hero__content {
  position: relative;
  z-index: 1;
  padding: 24px 24px 32px;
  width: 100%;
}
.cat-hero__title {
  font-size: clamp(1.75rem, 5vw, 3rem);
  font-weight: 900;
  letter-spacing: -.03em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.1;
}
.cat-hero__count {
  font-size: 11px;
  color: rgba(255,255,255,.7);
  letter-spacing: .08em;
  margin-top: 6px;
}

/* Sin imagen */
.cat-header-plain {
  padding: 40px 0 24px;
  border-bottom: 1px solid var(--clr-border);
  margin-bottom: 32px;
}
.cat-header-plain h1 {
  font-size: clamp(2rem, 6vw, 4rem);
  font-weight: 900;
  letter-spacing: -.03em;
  text-transform: uppercase;
  line-height: 1;
}

/* =================================================================
   HERO CAROUSEL
   ================================================================= */
.hero-carousel {
    position: relative;
    width: 100%;
    height: 100svh;          /* full viewport height */
    min-height: 540px;
    max-height: 960px;
    overflow: hidden;
    background: #0a0a0a;
}

.hero-carousel__track {
    display: flex;
    height: 100%;
    transition: transform 600ms cubic-bezier(.65,0,.35,1);
    will-change: transform;
}

/* ── Individual slide ─────────────────────────────────────── */
.hero-slide {
    position: relative;
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.hero-slide__bg {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 8000ms ease;
}

.hero-carousel__track .hero-slide.is-active .hero-slide__bg {
    transform: scale(1.05);   /* slow Ken Burns */
}

.hero-slide__bg--placeholder {
    background: linear-gradient(135deg, #111 0%, #222 50%, #0a0a0a 100%);
}

.hero-slide__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(0,0,0,.72) 0%,
        rgba(0,0,0,.38) 55%,
        rgba(0,0,0,.10) 100%
    );
}

.hero-slide--dark-text .hero-slide__overlay {
    background: linear-gradient(
        to right,
        rgba(255,255,255,.7) 0%,
        rgba(255,255,255,.3) 55%,
        rgba(255,255,255,0) 100%
    );
}

/* ── Slide content ─────────────────────────────────────────── */
.hero-slide__content {
    position: relative;
    z-index: 2;
    color: #fff;
    padding-block: 80px;
    max-width: 620px;
}

.hero-slide--dark-text .hero-slide__content { color: #111; }

.hero-slide__eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .22em;
    text-transform: uppercase;
    opacity: .75;
    margin-bottom: 16px;
    transform: translateY(20px);
    opacity: 0;
    animation: slideUp 700ms 200ms forwards;
}

.hero-slide__title {
    font-size: clamp(3rem, 9vw, 8rem);
    font-weight: 900;
    letter-spacing: -.04em;
    line-height: .95;
    text-transform: uppercase;
    margin-bottom: 20px;
    transform: translateY(24px);
    opacity: 0;
    animation: slideUp 700ms 350ms forwards;
}

.hero-slide__sub {
    font-size: clamp(.9rem, 1.8vw, 1.15rem);
    font-weight: 300;
    line-height: 1.55;
    opacity: .82;
    max-width: 420px;
    margin-bottom: 32px;
    transform: translateY(20px);
    opacity: 0;
    animation: slideUp 700ms 500ms forwards;
}

.hero-slide__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    color: #000;
    padding: 14px 28px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    transition: background 220ms, color 220ms, transform 100ms;
    transform: translateY(20px);
    opacity: 0;
    animation: slideUp 700ms 650ms forwards;
}

.hero-slide--dark-text .hero-slide__cta { background: #000; color: #fff; }
.hero-slide__cta:hover { opacity: .88; transform: translateY(-1px) !important; }

@keyframes slideUp {
    to { transform: translateY(0); opacity: 1; }
}

/* Cuando el slide NO es el activo, resetear animaciones */
.hero-slide:not(.is-active) .hero-slide__eyebrow,
.hero-slide:not(.is-active) .hero-slide__title,
.hero-slide:not(.is-active) .hero-slide__sub,
.hero-slide:not(.is-active) .hero-slide__cta {
    animation: none;
    opacity: 0;
    transform: translateY(20px);
}

/* ── Flechas ────────────────────────────────────────────────── */
.hero-carousel__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 52px; height: 52px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    backdrop-filter: blur(8px);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 220ms, border-color 220ms;
}
.hero-carousel__arrow:hover { background: rgba(255,255,255,.25); }
.hero-carousel__arrow--prev { left: 24px; }
.hero-carousel__arrow--next { right: 24px; }

@media (max-width: 640px) {
    .hero-carousel__arrow { width: 40px; height: 40px; }
    .hero-carousel__arrow--prev { left: 12px; }
    .hero-carousel__arrow--next { right: 12px; }
}

/* ── Dots ────────────────────────────────────────────────────── */
.hero-carousel__dots {
    position: absolute;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    gap: 8px;
}

.hero-carousel__dot {
    width: 6px; height: 6px;
    border-radius: 3px;
    background: rgba(255,255,255,.4);
    border: none;
    cursor: pointer;
    transition: width 300ms ease, background 300ms ease;
    padding: 0;
}
.hero-carousel__dot.is-active {
    width: 28px;
    background: #fff;
}

/* ── Scroll hint ─────────────────────────────────────────────── */
.hero-carousel__scroll-hint {
    position: absolute;
    bottom: 28px;
    right: 32px;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,.5);
    font-size: 9px;
    letter-spacing: .16em;
    text-transform: uppercase;
    animation: bounce 2s ease-in-out infinite;
}

@keyframes bounce {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(5px); }
}


/* =================================================================
   TICKER / MARQUEE
   ================================================================= */
.ticker {
    overflow: hidden;
    background: var(--clr-accent);
    color: var(--clr-accent-inv);
    padding-block: 12px;
    border-block: 1px solid rgba(0,0,0,.1);
}

.ticker__track {
    display: flex;
    gap: 0;
    animation: ticker-scroll 28s linear infinite;
    white-space: nowrap;
    width: max-content;
}

.ticker:hover .ticker__track { animation-play-state: paused; }

@keyframes ticker-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

.ticker__item {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .22em;
    text-transform: uppercase;
    padding: 0 20px;
}

.ticker__sep {
    font-size: 11px;
    opacity: .45;
    padding: 0 4px;
}


/* =================================================================
   SECTION HELPERS
   ================================================================= */
.section__eyebrow {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
    margin-bottom: 6px;
}


/* =================================================================
   CATEGORIES GRID (Shop by Category)
   ================================================================= */
.cats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-3);
}

@media (min-width: 640px)  { .cats-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .cats-grid { grid-template-columns: repeat(6, 1fr); gap: var(--sp-4); } }

.cat-card {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    text-decoration: none;
    color: var(--clr-text);
}

.cat-card__img-wrap {
    position: relative;
    aspect-ratio: 2/3;
    overflow: hidden;
    background: var(--clr-surface);
}

.cat-card__img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform 500ms ease;
}

.cat-card:hover .cat-card__img { transform: scale(1.06); }

.cat-card__img--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--clr-surface);
}

.cat-card__emoji {
    font-size: 3rem;
    line-height: 1;
    opacity: .4;
}

.cat-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.55) 0%, transparent 55%);
    opacity: 0;
    transition: opacity 300ms ease;
}

.cat-card:hover .cat-card__overlay { opacity: 1; }

.cat-card__info {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.cat-card__icon {
    font-size: 18px;
    line-height: 1;
}

.cat-card__name {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.cat-card__count {
    font-size: 10px;
    color: var(--clr-text-muted);
    letter-spacing: .04em;
    font-family: var(--font-mono, monospace);
}


/* =================================================================
   BRAND STATEMENT
   ================================================================= */
.brand-statement {
    padding-block: 120px;
    text-align: center;
    background: var(--clr-accent);
    color: var(--clr-accent-inv);
    margin-top: var(--sp-24);
}

.brand-statement__quote {
    font-size: clamp(2.5rem, 7vw, 6.5rem);
    font-weight: 900;
    letter-spacing: -.04em;
    text-transform: uppercase;
    line-height: 1;
    margin-bottom: 48px;
}

.brand-statement__quote p { margin: 0; }

.brand-statement__quote--accent {
    -webkit-text-stroke: 2px var(--clr-accent-inv);
    color: transparent;
}

.brand-statement__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--clr-accent-inv);
    color: var(--clr-accent);
    padding: 14px 32px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    transition: opacity 220ms;
}
.brand-statement__cta:hover { opacity: .8; }

/* =================================================================
   DROPS CAROUSEL
   ================================================================= */
.drops-carousel-wrap {
    position: relative;
    overflow: hidden;          /* evita el scroll horizontal */
}

.drops-carousel {
    display: flex;
    gap: var(--sp-4);
    transition: transform 420ms cubic-bezier(.65,0,.35,1);
    will-change: transform;
    /* Sin overflow visible — el wrap lo contiene */
}

.drops-slide {
    flex: 0 0 calc(50% - var(--sp-2));   /* 2 cards en mobile */
    min-width: 0;
}

@media (min-width: 640px) {
    .drops-slide { flex: 0 0 calc(33.333% - var(--sp-3)); }   /* 3 en tablet */
}
@media (min-width: 1024px) {
    .drops-slide { flex: 0 0 calc(25% - var(--sp-3)); }       /* 4 en desktop */
}

/* Flechas */
.drops-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 44px; height: 44px;
    background: var(--clr-bg);
    border: 1.5px solid var(--clr-border);
    color: var(--clr-text);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 200ms, border-color 200ms, opacity 200ms;
    box-shadow: 0 4px 16px rgba(0,0,0,.18);
}
.drops-arrow:hover { background: var(--clr-accent); color: var(--clr-accent-inv); border-color: var(--clr-accent); }
.drops-arrow:disabled,
.drops-arrow.is-hidden { opacity: 0; pointer-events: none; }

.drops-arrow--prev { left: -12px; }
.drops-arrow--next { right: -12px; }

@media (max-width: 767px) {
    .drops-arrow--prev { left: 4px; }
    .drops-arrow--next { right: 4px; }
}


/* =================================================================
   FIX GRID — Alturas uniformes en tarjetas de producto
   ================================================================= */




/* Ocultar texto nativo de WC */
.woocommerce-result-count { display: none !important; }

/* =================================================================
   LOGO IMAGEN
   ================================================================= */
.site-logo--img { display: flex; align-items: center; }
.site-logo__img {
    height: 44px;
    width: auto;
    max-width: 180px;
    object-fit: contain;
    display: block;
}

/* =================================================================
   TEMA AMARILLO — overrides específicos
   ================================================================= */
.dollar-banner   { font-weight: 700; }
.price-dual__ars { color: var(--clr-accent); }

/* Scrollbar */
* { scrollbar-color: var(--clr-accent) var(--clr-surface); scrollbar-width: thin; }

/* Focus ring */
:focus-visible { outline: 2px solid var(--clr-accent); outline-offset: 2px; }

/* =================================================================
   ARCHIVE TOOLBAR — fix layout
   ================================================================= */
.archive-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 0 24px;
    border-bottom: 1px solid var(--clr-border);
    margin-bottom: 32px;
    gap: 16px;
}

.archive-count {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
}

.archive-sort .woocommerce-ordering {
    margin: 0;
}

.archive-sort select,
.archive-sort .woocommerce-ordering select {
    border: 1.5px solid var(--clr-border) !important;
    background: var(--clr-bg) !important;
    color: var(--clr-text) !important;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 10px 14px !important;
    cursor: pointer;
    border-radius: 0 !important;
    min-width: 160px;
    appearance: auto;
}

/* Empty state */
.empty-state {
    text-align: center;
    padding: 80px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.empty-state h2 {
    font-size: var(--fs-lg);
    font-weight: var(--fw-bold);
}

.empty-state p {
    color: var(--clr-text-muted);
    max-width: 360px;
}

.empty-state .btn-atc {
    width: auto;
    display: inline-flex;
    padding: 0 40px;
    margin-top: 8px;
}

/* =================================================================
   SW PAGINATION
   ================================================================= */
.sw-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 56px;
    padding-bottom: 64px;
}

.sw-page-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 8px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .08em;
    color: var(--clr-text-muted);
    border: 1.5px solid var(--clr-border);
    background: transparent;
    text-decoration: none;
    transition: border-color 200ms, color 200ms, background 200ms;
    cursor: pointer;
}

a.sw-page-btn:hover {
    border-color: var(--clr-accent);
    color: var(--clr-text);
    background: var(--clr-surface);
}

.sw-page-btn.is-active {
    background: var(--clr-accent);
    color: var(--clr-accent-inv);
    border-color: var(--clr-accent);
    cursor: default;
}

.sw-page-btn.is-dots {
    border-color: transparent;
    background: transparent;
    cursor: default;
    letter-spacing: 0;
}

.sw-page-btn.is-arrow {
    font-size: 16px;
    font-weight: 400;
}

/* Prevenir scroll horizontal en toda la página */
html, body { overflow-x: hidden; max-width: 100%; }


/* =================================================================
   ANIMACIONES — versión correcta
   Se activan VÍA .is-visible para no pelear con el sistema reveal
   ================================================================= */

/* ── Keyframes ──────────────────────────────────────────────────── */
/* =================================================================
   ANIMACIONES — escritas desde cero, sistema limpio
   ================================================================= */

/* ── Keyframes ────────────────────────────────────────────────────── */
@keyframes sw-fadeUp    { from { opacity:0; transform:translateY(28px); } to { opacity:1; transform:translateY(0); } }
@keyframes sw-fadeLeft  { from { opacity:0; transform:translateX(-28px);} to { opacity:1; transform:translateX(0); } }
@keyframes sw-fadeRight { from { opacity:0; transform:translateX(28px); } to { opacity:1; transform:translateX(0); } }
@keyframes sw-scaleIn   { from { opacity:0; transform:scale(.88);       } to { opacity:1; transform:scale(1);     } }
@keyframes sw-popBadge  { 0%{opacity:0;transform:scale(0) rotate(-12deg)} 70%{transform:scale(1.18) rotate(3deg)} 100%{opacity:1;transform:scale(1) rotate(0)} }
@keyframes sw-floatLogo { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes sw-bumpCount { 0%{transform:scale(.6)} 65%{transform:scale(1.25)} 100%{transform:scale(1)} }
@keyframes sw-glow      { 0%,100%{box-shadow:0 0 0 0 rgba(255,204,0,.55)} 50%{box-shadow:0 0 0 10px rgba(255,204,0,0)} }
@keyframes sw-underline { from{transform:scaleX(0);transform-origin:left} to{transform:scaleX(1)} }

/* ── Header entra desde arriba ──────────────────────────────────── */
.site-header {
    animation: sw-fadeUp 420ms ease both;
}
.dollar-banner {
    animation: sw-fadeUp 420ms ease 80ms both;
}

/* ── Logo flota ─────────────────────────────────────────────────── */
.site-logo {
    display: inline-block;
    animation: sw-floatLogo 4s ease-in-out 1.2s infinite;
}
.site-logo:hover { animation-play-state: paused; }

/* ── Botones del header: rebote en hover ────────────────────────── */
.header-btn {
    transition: transform 180ms cubic-bezier(.34,1.56,.64,1), color 140ms ease;
}
.header-btn:hover  { transform: scale(1.14); }
.header-btn:active { transform: scale(.88);  }

/* ── Nav links: subrayado que crece desde la izquierda ─────────── */
.site-nav a { position: relative; }
.site-nav a::after {
    content: '';
    position: absolute;
    bottom: -3px; left: 0;
    width: 100%; height: 1.5px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 220ms ease;
}
.site-nav a:hover::after { transform: scaleX(1); }

/* ── Reveal: fade up suave (sistema existente intacto) ──────────── */
.reveal {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 550ms ease, transform 550ms cubic-bezier(.25,.46,.45,.94);
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ── Section header: hijos animan cuando padre pasa a is-visible ── */
.section__header.is-visible .section__eyebrow {
    animation: sw-fadeLeft 480ms ease both;
}
.section__header.is-visible .section__title {
    animation: sw-fadeLeft 480ms ease 70ms both;
}
.section__header.is-visible .section__link {
    animation: sw-fadeRight 480ms ease 90ms both;
}

/* ── Brand statement ────────────────────────────────────────────── */
.brand-statement.is-visible .brand-statement__quote p:first-child {
    animation: sw-fadeLeft 600ms cubic-bezier(.25,.46,.45,.94) both;
}
.brand-statement.is-visible .brand-statement__quote p:last-child {
    animation: sw-fadeRight 600ms cubic-bezier(.25,.46,.45,.94) 110ms both;
}
.brand-statement.is-visible .brand-statement__cta {
    animation: sw-scaleIn 520ms cubic-bezier(.34,1.56,.64,1) 260ms both;
}

/* ── Cards del grid: entran escalonadas ─────────────────────────── */
.product-card {
    animation: sw-fadeUp 380ms ease both;
    transition: transform 250ms cubic-bezier(.34,1.56,.64,1),
                box-shadow 250ms ease;
}
.products-grid .product-card:nth-child(1)  { animation-delay:  20ms; }
.products-grid .product-card:nth-child(2)  { animation-delay:  70ms; }
.products-grid .product-card:nth-child(3)  { animation-delay: 120ms; }
.products-grid .product-card:nth-child(4)  { animation-delay: 170ms; }
.products-grid .product-card:nth-child(5)  { animation-delay: 220ms; }
.products-grid .product-card:nth-child(6)  { animation-delay: 270ms; }
.products-grid .product-card:nth-child(7)  { animation-delay: 320ms; }
.products-grid .product-card:nth-child(8)  { animation-delay: 320ms; }
.products-grid .product-card:nth-child(n+9){ animation-delay: 350ms; }

/* Card: sube en hover */
.product-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 16px 40px rgba(0,0,0,.22);
}

/* ── Badge SALE: pop con rebote ─────────────────────────────────── */
.product-card__badge {
    animation: sw-popBadge 420ms cubic-bezier(.34,1.56,.64,1) 180ms both;
}

/* ── Imagen card: zoom suave en hover ───────────────────────────── */
.product-card__img {
    transition: opacity 350ms ease, transform 550ms cubic-bezier(.25,.46,.45,.94) !important;
}

/* ── Cart badge: pop al agregar ─────────────────────────────────── */
.cart-count.is-bumping {
    animation: sw-bumpCount 340ms cubic-bezier(.34,1.56,.64,1) both !important;
}

/* ── Botón ATC: pulso de glow ───────────────────────────────────── */
.wc-atc-wrapper .single_add_to_cart_button:not(:hover):not(:disabled) {
    animation: sw-glow 2.4s ease-in-out 1.8s infinite;
}

/* ── Botones: micro-press en active ─────────────────────────────── */
.btn-atc,
.hero-slide__cta,
.brand-statement__cta {
    transition: transform 110ms ease, opacity 180ms ease !important;
}
.btn-atc:active,
.hero-slide__cta:active,
.brand-statement__cta:active { transform: scale(.96) !important; }

/* ── Pagination: sube en hover ──────────────────────────────────── */
a.sw-page-btn {
    transition: background 160ms ease, border-color 160ms ease,
                color 160ms ease, transform 130ms ease !important;
}
a.sw-page-btn:hover  { transform: translateY(-2px); }
a.sw-page-btn:active { transform: translateY(0);    }

/* ── Flechas carrusel y drops ───────────────────────────────────── */
.hero-carousel__arrow svg,
.drops-arrow svg {
    transition: transform 180ms ease;
    display: block;
}
.hero-carousel__arrow--prev:hover svg,
.drops-arrow--prev:hover svg  { transform: translateX(-4px); }
.hero-carousel__arrow--next:hover svg,
.drops-arrow--next:hover svg  { transform: translateX(4px);  }

/* ── Category cards ─────────────────────────────────────────────── */
.cat-card {
    transition: transform 240ms cubic-bezier(.34,1.56,.64,1);
}
.cat-card:hover { transform: translateY(-4px); }
.cat-card__img  { transition: transform 580ms ease !important; }

/* ── Cats drawer items: indent en hover ─────────────────────────── */
.cats-drawer__item {
    transition: background 160ms ease, padding-left 200ms ease;
}
.cats-drawer__item:not(.is-active):hover { padding-left: 30px; }

/* ── Accordion flecha gira ──────────────────────────────────────── */
.accordion-icon {
    display: inline-block;
    transition: transform 260ms cubic-bezier(.25,.46,.45,.94);
}
.accordion-item.is-open .accordion-icon { transform: rotate(180deg); }

/* ── Mini-cart item: slide out al eliminar ──────────────────────── */
.woocommerce-mini-cart__item {
    transition: opacity 220ms ease, transform 220ms ease;
}
.woocommerce-mini-cart__item.is-removing {
    opacity: 0 !important;
    transform: translateX(20px) !important;
    pointer-events: none;
}

/* ── Scroll suave ───────────────────────────────────────────────── */
html { scroll-behavior: smooth; }

/* ── Respetar prefers-reduced-motion ────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
}

/* =================================================================
   COLOR SWATCHES
   ================================================================= */

/* Ocultar el select nativo de color cuando hay swatches */
.sw-has-swatches .variations select[data-attribute_name*="colo"],
.sw-has-swatches .variations select[id*="colo"] {
    display: none !important;
}

/* Label del atributo */
.sw-swatch-row {
    margin-bottom: 18px;
}
.sw-swatch-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.sw-swatch-label span.sw-selected-name {
    font-weight: 400;
    color: var(--clr-text);
    text-transform: none;
    letter-spacing: 0;
}

/* Contenedor de círculos */
.sw-swatches {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

/* Círculo individual */
.sw-swatch {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2.5px solid transparent;
    cursor: pointer;
    position: relative;
    transition: transform 200ms cubic-bezier(.34,1.56,.64,1),
                border-color 160ms ease,
                box-shadow 160ms ease;
    outline: none;
    background-clip: padding-box;
}

/* Ring exterior al seleccionar */
.sw-swatch::after {
    content: '';
    position: absolute;
    inset: -5px;
    border-radius: 50%;
    border: 2px solid transparent;
    transition: border-color 160ms ease;
}

.sw-swatch:hover {
    transform: scale(1.12);
    box-shadow: 0 4px 12px rgba(0,0,0,.25);
}

.sw-swatch.is-selected {
    transform: scale(1.08);
    box-shadow: 0 4px 14px rgba(0,0,0,.3);
}
.sw-swatch.is-selected::after {
    border-color: var(--clr-accent);
}

/* Swatch claro: borde oscuro para que se vea */
.sw-swatch.is-light {
    border-color: var(--clr-border) !important;
}

/* Swatch disabled (sin stock) */
.sw-swatch.is-disabled {
    opacity: .32;
    cursor: not-allowed;
    transform: none !important;
}
.sw-swatch.is-disabled::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 4px,
        rgba(0,0,0,.35) 4px,
        rgba(0,0,0,.35) 5px
    );
}

/* Tooltip con el nombre */
.sw-swatch[title] {
    position: relative;
}

/* =================================================================
   CHECKOUT CUSTOM
   ================================================================= */
.sw-checkout {
    padding: 40px 0 80px;
}

.sw-checkout__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 32px;
}
@media (min-width: 900px) {
    .sw-checkout__grid {
        grid-template-columns: 1.15fr 0.85fr;
        gap: 48px;
        align-items: start;
    }
}

/* Sección */
.sw-checkout__section {
    border: 1.5px solid var(--clr-border);
    padding: 24px;
    margin-bottom: 20px;
    background: var(--clr-bg);
}

.sw-checkout__section-title {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    color: var(--clr-text);
}

.sw-step-num {
    width: 26px; height: 26px;
    background: var(--clr-accent);
    color: var(--clr-accent-inv);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 900;
    flex-shrink: 0;
}

/* Grillas de campos */
.sw-row-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.sw-row-3 {
    display: grid;
    grid-template-columns: 1fr 1.4fr 1fr;
    gap: 16px;
}
@media (max-width: 600px) {
    .sw-row-2, .sw-row-3 { grid-template-columns: 1fr; }
}

/* Campos WooCommerce */
.sw-field p.form-row,
.sw-field { margin-bottom: 0 !important; }

.woocommerce-checkout .form-row { margin-bottom: 16px !important; }

.woocommerce-checkout .form-row label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
    display: block;
    margin-bottom: 6px;
}

.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout select,
.woocommerce-checkout textarea,
.sw-input {
    width: 100%;
    background: var(--clr-surface) !important;
    border: 1.5px solid var(--clr-border) !important;
    color: var(--clr-text) !important;
    padding: 12px 14px !important;
    font-size: 14px !important;
    font-family: inherit !important;
    border-radius: 0 !important;
    outline: none !important;
    transition: border-color 160ms ease !important;
    box-sizing: border-box;
    -webkit-appearance: none;
}

.woocommerce-checkout input:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus,
.sw-input:focus {
    border-color: var(--clr-accent) !important;
    box-shadow: none !important;
}

.woocommerce-checkout .woocommerce-invalid input,
.woocommerce-checkout .woocommerce-invalid select {
    border-color: #e05252 !important;
}

/* Order review */
.sw-order-review__head {
    display: flex;
    justify-content: space-between;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--clr-text-muted);
    padding-bottom: 12px;
    border-bottom: 1px solid var(--clr-border);
    margin-bottom: 12px;
}

.sw-order-review__item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--clr-border);
}

.sw-order-review__img {
    width: 52px; height: 52px;
    object-fit: cover;
    flex-shrink: 0;
}

.sw-order-review__info { flex: 1; min-width: 0; }
.sw-order-review__name {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sw-order-review__qty { font-size: 11px; color: var(--clr-text-muted); margin-top: 2px; }

.sw-order-review__price { text-align: right; flex-shrink: 0; }
.sw-price-ars { display: block; font-weight: 700; font-size: 13px; }
.sw-price-usd { display: block; font-size: 10px; color: var(--clr-text-muted); margin-top: 2px; }

/* Totales */
.sw-order-review__totals { margin-top: 12px; }
.sw-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    font-size: 12px;
    border-bottom: 1px solid var(--clr-border);
    color: var(--clr-text-muted);
}
.sw-total-row--grand {
    padding-top: 14px;
    font-size: 13px;
    font-weight: 700;
    color: var(--clr-text);
    border-bottom: none;
}
.sw-grand-total { text-align: right; }
.sw-grand-total .sw-price-ars { font-size: 16px; font-weight: 900; }

/* Cupón */
.sw-coupon { margin-top: 16px; }
.sw-coupon__toggle {
    background: none;
    border: none;
    color: var(--clr-text-muted);
    font-size: 12px;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.sw-coupon__form {
    display: flex;
    gap: 10px;
    margin-top: 12px;
}
.sw-coupon__btn {
    background: var(--clr-text);
    color: var(--clr-bg);
    border: none;
    padding: 0 20px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 160ms ease;
}
.sw-coupon__btn:hover { opacity: .8; }

/* Métodos de pago */
.sw-payment-methods {
    list-style: none;
    margin: 0 0 16px !important;
    padding: 0 !important;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.sw-payment-methods li,
.sw-payment-methods .wc_payment_method {
    border: 1.5px solid var(--clr-border);
    padding: 16px;
    cursor: pointer;
    transition: border-color 160ms ease, background 160ms ease;
}

.sw-payment-methods li:has(input:checked),
.sw-payment-methods .wc_payment_method:has(input:checked) {
    border-color: var(--clr-accent);
    background: rgba(255,204,0,.05);
}

.sw-payment-methods input[type="radio"] {
    accent-color: var(--clr-accent);
    margin-right: 10px;
    cursor: pointer;
}

.sw-payment-methods label {
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
}

.payment_box {
    margin-top: 12px;
    padding: 14px;
    background: var(--clr-surface);
    border: 1px solid var(--clr-border);
    font-size: 13px;
    color: var(--clr-text-muted);
}

/* Botón pagar */
.sw-btn-place-order {
    width: 100% !important;
    background: var(--clr-accent) !important;
    color: var(--clr-accent-inv) !important;
    border: none !important;
    padding: 18px !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    border-radius: 0 !important;
    transition: opacity 180ms ease !important;
    margin-top: 8px !important;
    display: block !important;
}
.sw-btn-place-order:hover { opacity: .88 !important; }

/* Badge seguro */
.sw-secure-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 11px;
    color: var(--clr-text-muted);
    margin-top: 14px;
}

/* Sticky en desktop */
@media (min-width: 900px) {
    .sw-checkout__right {
        position: sticky;
        top: calc(64px + 24px);
    }
}

/* =================================================================
   CHECKOUT — estilos sobre el HTML nativo de WooCommerce
   Sin override de template, 100% CSS
   ================================================================= */

/* Layout 2 columnas */
.woocommerce-checkout #customer_details {
    float: none !important;
    width: 100% !important;
}

.woocommerce-page.woocommerce-checkout .woocommerce {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
}

@media (min-width: 900px) {
    .woocommerce-page.woocommerce-checkout .col2-set {
        float: none !important;
        width: 100% !important;
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 40px !important;
        align-items: start !important;
        margin-bottom: 32px !important;
    }
    .woocommerce-page.woocommerce-checkout .col2-set .col-1,
    .woocommerce-page.woocommerce-checkout .col2-set .col-2 {
        float: none !important;
        width: 100% !important;
    }
}

/* Order review sticky en desktop */
@media (min-width: 900px) {
    #order_review_heading,
    #order_review {
        position: sticky;
        top: calc(64px + 20px);
    }
}

/* Sección con borde */
.woocommerce-billing-fields,
.woocommerce-shipping-fields,
.woocommerce-additional-fields,
#order_review {
    border: 1.5px solid var(--clr-border);
    padding: 24px !important;
    margin-bottom: 20px !important;
    background: var(--clr-bg);
}

/* Títulos de sección */
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3,
#order_review_heading {
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    color: var(--clr-text) !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid var(--clr-border) !important;
}

/* Labels */
.woocommerce-checkout .form-row label,
.woocommerce-checkout p.form-row label {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase !important;
    color: var(--clr-text-muted) !important;
    margin-bottom: 6px !important;
    display: block !important;
}

/* Inputs */
.woocommerce-checkout input.input-text,
.woocommerce-checkout select,
.woocommerce-checkout textarea {
    background: var(--clr-surface) !important;
    border: 1.5px solid var(--clr-border) !important;
    color: var(--clr-text) !important;
    padding: 12px 14px !important;
    font-size: 14px !important;
    font-family: inherit !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    width: 100% !important;
    -webkit-appearance: none !important;
    transition: border-color 160ms ease !important;
}

.woocommerce-checkout input.input-text:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
    border-color: var(--clr-accent) !important;
    box-shadow: none !important;
    outline: none !important;
}

/* Error de validación */
.woocommerce-checkout .woocommerce-invalid input.input-text,
.woocommerce-checkout .woocommerce-invalid select {
    border-color: #e05252 !important;
}

/* Order review table */
.woocommerce-checkout-review-order-table {
    width: 100% !important;
    border-collapse: collapse !important;
    margin-bottom: 0 !important;
}

.woocommerce-checkout-review-order-table thead th {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    color: var(--clr-text-muted) !important;
    padding: 0 0 12px !important;
    border-bottom: 1px solid var(--clr-border) !important;
}

.woocommerce-checkout-review-order-table tbody tr {
    border-bottom: 1px solid var(--clr-border) !important;
}

.woocommerce-checkout-review-order-table tbody td {
    padding: 12px 0 !important;
    font-size: 13px !important;
    color: var(--clr-text) !important;
}

.woocommerce-checkout-review-order-table tfoot tr td,
.woocommerce-checkout-review-order-table tfoot tr th {
    padding: 10px 0 !important;
    font-size: 12px !important;
    color: var(--clr-text-muted) !important;
    border-top: 1px solid var(--clr-border) !important;
}

.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
    font-size: 16px !important;
    font-weight: 900 !important;
    color: var(--clr-text) !important;
}

/* Métodos de pago */
#payment {
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
}

#payment ul.payment_methods {
    border: none !important;
    padding: 0 !important;
    margin: 0 0 16px !important;
    list-style: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

#payment ul.payment_methods li {
    border: 1.5px solid var(--clr-border) !important;
    padding: 16px !important;
    background: var(--clr-bg) !important;
    margin: 0 !important;
    cursor: pointer !important;
    transition: border-color 160ms ease !important;
}

#payment ul.payment_methods li:has(input:checked) {
    border-color: var(--clr-accent) !important;
    background: rgba(255,204,0,.04) !important;
}

#payment ul.payment_methods li label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--clr-text) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

#payment ul.payment_methods li input[type="radio"] {
    accent-color: var(--clr-accent) !important;
    width: 16px !important;
    height: 16px !important;
    cursor: pointer !important;
}

#payment .payment_box {
    background: var(--clr-surface) !important;
    border: 1px solid var(--clr-border) !important;
    padding: 14px !important;
    margin-top: 12px !important;
    font-size: 13px !important;
    color: var(--clr-text-muted) !important;
    border-radius: 0 !important;
}

/* Botón Place Order */
#payment #place_order,
.woocommerce-checkout #place_order {
    width: 100% !important;
    background: var(--clr-accent) !important;
    color: var(--clr-accent-inv) !important;
    border: none !important;
    padding: 18px !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    border-radius: 0 !important;
    display: block !important;
    transition: opacity 180ms ease !important;
    margin-top: 8px !important;
    font-family: inherit !important;
}

#payment #place_order:hover {
    opacity: .88 !important;
}

/* Mensaje de seguridad */
#payment .woocommerce-terms-and-conditions-wrapper {
    font-size: 11px !important;
    color: var(--clr-text-muted) !important;
    margin-top: 10px !important;
}

/* Notices de WooCommerce */
.woocommerce-NoticeGroup {
    margin-bottom: 20px;
}
.woocommerce-error,
.woocommerce-message,
.woocommerce-info {
    padding: 14px 16px !important;
    border-left: 3px solid var(--clr-accent) !important;
    background: var(--clr-surface) !important;
    color: var(--clr-text) !important;
    font-size: 13px !important;
    list-style: none !important;
    margin-bottom: 16px !important;
    border-radius: 0 !important;
}
.woocommerce-error { border-left-color: #e05252 !important; }

/* Loader overlay de WC */
.blockUI.blockOverlay {
    background: var(--clr-bg) !important;
    opacity: .7 !important;
}

/* Logo desde Customizer */
.custom-logo-link {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    animation: sw-floatLogo 4s ease-in-out 1.2s infinite;
    /* ocupa el mismo lugar que .site-logo en el grid del header */
    order: 0;
}
.custom-logo-link:hover { animation-play-state: paused; }
.custom-logo-link img.custom-logo {
    height: 44px !important;
    width: auto !important;
    max-width: 200px !important;
    object-fit: contain;
    display: block;
}
