*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* === AZULES (antes primary) === */
  --primary:#002E57;          /* Azul oscuro base */
  --primary-dark:#000E17;     /* Negro azulado */
  --primary-mid:#00779D;      /* Azul claro */

  /* === ACENTOS (antes naranja/amarillo) === */
  --accent:#F5CC3E;           /* Amarillo principal */
  --accent-light:#FFF1A6;     /* Amarillo suave */

  /* === GOLD (unificado con accent) === */
  --gold:#F5CC3E;

  /* === NEUTROS === */
  --white:#FFFFFF;
  --off-white:#F4F6F7;        /* Neutral frío */

  /* === TEXTO === */
  --text:#000E17;             /* Negro base */
  --text-muted:#5F6B76;       /* Gris azulado */
  --text-light:#9AA6B2;

  /* === BORDES === */
  --border:#D6DEE3;
  --border-strong:#AAB8C2;

  /* === FONDOS === */
  --card-bg:#FFFFFF;
  --bg:#F4F6F7;

  /* === TIPOGRAFÍA === */
  --font-display:'Barlow Condensed',sans-serif;
  --font-body:'Barlow',sans-serif;

  /* === UI === */
  --radius:12px;
  --radius-sm:8px;
  --radius-lg:20px;

  /* === SOMBRAS (coherentes con azul nuevo) === */
  --shadow:0 4px 24px rgba(0,46,87,0.10);
  --shadow-hover:0 12px 40px rgba(0,46,87,0.18);

  --mobile-nav-h:64px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.6;
  min-height:100vh;
  padding-bottom:calc(var(--mobile-nav-h) + var(--safe-bottom));
}
@media(min-width:769px){body{padding-bottom:0}}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--off-white)}
::-webkit-scrollbar-thumb{background:var(--primary-mid);border-radius:3px}

/* ── HEADER ── */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--primary);
  border-bottom:3px solid var(--accent);
}
.header-inner{
  max-width:1320px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1.5rem;height:64px;gap:1rem;
}
.logo-area{display:flex;align-items:center;gap:.6rem;text-decoration:none;flex-shrink:0}
.logo-mark{
  width:90px;height:90px;
  border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:900;font-size:16px;
  position:relative;overflow:hidden;
}
.logo-mark::after{content:'';position:absolute;inset:0;}
.logo-name{font-family:var(--font-display);font-weight:800;font-size:20px;color:#fff;letter-spacing:-.01em;line-height:1}
.logo-name span{color:var(--accent-light)}
.logo-tagline{font-size:9px;color:rgba(255,255,255,.5);letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
.header-search{
  flex:1;max-width:460px;
  display:flex;align-items:center;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:9px;overflow:hidden;transition:background .2s,border-color .2s;
}
.header-search:focus-within{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4)}
.header-search input{
  flex:1;background:transparent;border:none;outline:none;
  padding:9px 14px;color:#fff;font-family:var(--font-body);font-size:14px;
}
.header-search input::placeholder{color:rgba(255,255,255,.45)}
.header-search button{
  background:var(--accent);border:none;cursor:pointer;
  padding:0 16px;height:100%;color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.05em;
  text-transform:uppercase;transition:background .15s;white-space:nowrap;
}
.header-search button:hover{background:#c41c24}
.header-actions{display:flex;align-items:center;gap:.6rem}
.nav-link{
  color:rgba(255,255,255,.7);font-size:13px;font-weight:500;
  text-decoration:none;padding:6px 9px;border-radius:6px;transition:all .15s;white-space:nowrap;
}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-link.active{color:#fff}
.cart-btn{
  display:flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:9px;padding:7px 13px;cursor:pointer;
  color:#fff;font-size:13px;font-weight:600;transition:all .15s;white-space:nowrap;
}
.cart-btn:hover{background:rgba(255,255,255,.2)}
.cart-badge{
  background:var(--accent);color:#fff;
  width:18px;height:18px;border-radius:50%;
  font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;
}

/* ── MOBILE TOP BAR (only visible on mobile) ── */
.mobile-top-bar{
  display:none;
  position:sticky;top:0;z-index:100;
  background:var(--primary);
  border-bottom:3px solid var(--accent);
  padding:0 1rem;height:56px;
  align-items:center;justify-content:space-between;gap:.75rem;
}
.mobile-top-bar .logo-area{flex-shrink:0}
.mobile-search-btn{
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:8px;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:#fff;font-size:16px;flex-shrink:0;
}
.mobile-cart-icon{
  background:var(--accent);border:none;
  border-radius:8px;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  position:relative;flex-shrink:0;
}
.mobile-cart-badge{
  position:absolute;top:-5px;right:-5px;
  background:var(--gold);color:var(--primary-dark);
  width:16px;height:16px;border-radius:50%;
  font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;
}

/* ── MOBILE SEARCH OVERLAY ── */
.mobile-search-overlay{
  display:none;
  position:fixed;inset:0;z-index:300;
  background:var(--primary-dark);
  flex-direction:column;
  padding:1rem;
}
.mobile-search-overlay.open{display:flex}
.mobile-search-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.mobile-search-close{
  background:rgba(255,255,255,.1);border:none;border-radius:8px;
  width:38px;height:38px;color:#fff;font-size:18px;cursor:pointer;flex-shrink:0;
}
.mobile-search-input{
  flex:1;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);
  border-radius:10px;padding:10px 14px;color:#fff;font-size:15px;outline:none;
  font-family:var(--font-body);
}
.mobile-search-input::placeholder{color:rgba(255,255,255,.4)}
.mobile-search-submit{
  background:var(--accent);border:none;border-radius:10px;
  padding:10px 20px;color:#fff;font-family:var(--font-display);
  font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;
}
.mobile-quick-cats{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}
.quick-cat-btn{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:20px;padding:6px 14px;font-size:13px;color:rgba(255,255,255,.7);
  cursor:pointer;transition:all .15s;font-weight:500;
}
.quick-cat-btn:hover,.quick-cat-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* ── BOTTOM NAV (mobile only) ── */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:200;
  background:var(--primary);
  border-top:2px solid var(--accent);
  padding:0 .5rem;
  padding-bottom:var(--safe-bottom);
  height:calc(var(--mobile-nav-h) + var(--safe-bottom));
  align-items:center;justify-content:space-around;
}
.bottom-nav-item{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:8px 12px;border-radius:10px;cursor:pointer;
  transition:all .15s;text-decoration:none;flex:1;
  position:relative;
}
.bottom-nav-item svg{width:22px;height:22px}
.bottom-nav-item .nav-icon path,.bottom-nav-item .nav-icon circle,.bottom-nav-item .nav-icon line,.bottom-nav-item .nav-icon rect{
  stroke:rgba(255,255,255,.45);transition:stroke .15s;
}
.bottom-nav-item .nav-label{font-size:10px;color:rgba(255,255,255,.45);font-weight:500;letter-spacing:.02em;transition:color .15s}
.bottom-nav-item.active .nav-icon path,.bottom-nav-item.active .nav-icon circle,.bottom-nav-item.active .nav-icon line,.bottom-nav-item.active .nav-icon rect{stroke:#fff}
.bottom-nav-item.active .nav-label{color:#fff}
.bottom-nav-item.active::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:36px;height:3px;background:var(--accent);border-radius:0 0 3px 3px;
}
.bottom-nav-center{
  background:var(--accent);border-radius:14px;
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(232,34,42,.4);flex-shrink:0;
  position:relative;top:-8px;cursor:pointer;
  border:3px solid var(--primary);
}
.bottom-nav-center svg path,.bottom-nav-center svg circle,.bottom-nav-center svg line{stroke:#fff}
.bottom-nav-cart-badge{
  position:absolute;top:-6px;right:-6px;
  background:var(--gold);color:var(--primary-dark);
  width:18px;height:18px;border-radius:50%;
  font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--primary);
}

/* ── HERO ── */
.hero{
  position:relative;overflow:hidden;
  padding:3.5rem 1.5rem 3rem;
}
.hero-bg-pattern{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 80% 50%, rgba(232,34,42,.12) 0%, transparent 55%),
    radial-gradient(circle at 10% 80%, rgba(245,166,35,.08) 0%, transparent 40%);
}
.hero-grid-lines{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:60px 60px;
}
.hero-inner{max-width:1320px;margin:0 auto;position:relative;z-index:1}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(232,34,42,.15);border:1px solid rgba(232,34,42,.3);
  border-radius:20px;padding:4px 12px;margin-bottom:1rem;
}
.hero-eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
.hero-eyebrow-text{font-size:11px;font-weight:600;color:rgba(255,255,255,.8);letter-spacing:.1em;text-transform:uppercase}
.hero-title{
  font-family:var(--font-display);font-weight:900;font-size:clamp(34px,5vw,60px);
  color:#fff;line-height:.95;letter-spacing:-.02em;
  margin-bottom:.5rem;text-transform:uppercase;
}
.hero-title em{color:var(--accent);font-style:normal}
.hero-subtitle{font-size:15px;color:rgba(255,255,255,.55);max-width:520px;margin-bottom:1.75rem;font-weight:300;line-height:1.6}
.hero-ctas{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2rem}
.cta-primary{
  background:var(--accent);color:#fff;border:none;border-radius:9px;
  padding:12px 24px;font-family:var(--font-display);font-weight:700;font-size:14px;
  letter-spacing:.05em;text-transform:uppercase;cursor:pointer;
  transition:all .2s;box-shadow:0 4px 20px rgba(232,34,42,.35);
}
.cta-primary:hover{background:#c41c24;transform:translateY(-1px)}
.cta-secondary{
  background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.25);
  border-radius:9px;padding:12px 24px;font-family:var(--font-display);font-weight:700;
  font-size:14px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:all .2s;
}
.cta-secondary:hover{background:rgba(255,255,255,.18)}
.hero-stats{display:flex;gap:2rem;flex-wrap:wrap;padding-top:1.75rem;border-top:1px solid rgba(255,255,255,.1)}
.hero-stat-n{font-family:var(--font-display);font-size:32px;font-weight:900;color:#fff;line-height:1}
.hero-stat-n span{color:var(--accent)}
.hero-stat-l{font-size:11px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}

/* ── MARQUEE ── */
.marquee-band{background:var(--accent);padding:9px 0;overflow:hidden;border-top:2px solid #c41c24}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:marquee 30s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:.6rem;padding:0 1.75rem;font-family:var(--font-display);font-weight:700;font-size:12px;color:#fff;letter-spacing:.08em;text-transform:uppercase}
.marquee-sep{width:4px;height:4px;background:rgba(255,255,255,.5);border-radius:50%}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── MAIN LAYOUT ── */
.main-wrap{max-width:1320px;margin:0 auto;padding:2rem 1.5rem;display:flex;gap:1.75rem;align-items:flex-start}

/* ── SIDEBAR ── */
.sidebar{width:230px;flex-shrink:0;position:sticky;top:80px}
.sidebar-block{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;margin-bottom:.75rem}
.sidebar-title{font-family:var(--font-display);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--primary);margin-bottom:.85rem;display:flex;align-items:center;gap:.4rem}
.sidebar-title::before{content:'';width:3px;height:14px;background:var(--accent);border-radius:2px}
.cat-list{display:flex;flex-direction:column;gap:.2rem}
.cat-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:7px;cursor:pointer;transition:all .15s;font-size:13px;color:var(--text-muted);border:1px solid transparent;font-weight:500}
.cat-item:hover{background:var(--off-white);color:var(--text);border-color:var(--border)}
.cat-item.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.cat-item.active .cat-count{background:rgba(255,255,255,.2);color:#fff}
.cat-count{font-size:10px;font-weight:700;background:var(--off-white);color:var(--text-muted);padding:2px 6px;border-radius:20px}
.price-row{display:flex;gap:.4rem;margin-bottom:.6rem}
.price-input{flex:1;padding:7px 9px;border:1px solid var(--border);border-radius:7px;font-family:var(--font-body);font-size:13px;color:var(--text);outline:none;background:var(--off-white);transition:border-color .15s}
.price-input:focus{border-color:var(--primary)}
.apply-btn{width:100%;background:var(--primary);color:#fff;border:none;border-radius:7px;padding:8px;cursor:pointer;font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.05em;text-transform:uppercase;transition:background .15s}
.apply-btn:hover{background:var(--primary-mid)}
.brand-list{display:flex;flex-direction:column;gap:.4rem}
.brand-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:13px;color:var(--text-muted);font-weight:500}
.brand-cb{width:15px;height:15px;border:2px solid var(--border-strong);border-radius:3px;flex-shrink:0;transition:all .15s;display:flex;align-items:center;justify-content:center}
.brand-item.checked .brand-cb{background:var(--primary);border-color:var(--primary)}
.brand-item.checked .brand-cb::after{content:'✓';color:#fff;font-size:9px}
.brand-item.checked{color:var(--text)}

/* ── PRODUCT AREA ── */
.product-area{flex:1;min-width:0}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.toolbar-right{display:flex;align-items:center;gap:.6rem}
.result-text{font-size:13px;color:var(--text-muted)}
.result-text strong{color:var(--primary);font-weight:700}
.sort-select{background:var(--card-bg);border:1px solid var(--border);border-radius:7px;padding:7px 12px;font-family:var(--font-body);font-size:13px;color:var(--text);outline:none;cursor:pointer;transition:border-color .15s}
.sort-select:focus{border-color:var(--primary)}
.view-toggle{display:flex;gap:.2rem}
.view-btn{width:32px;height:32px;border:1px solid var(--border);background:var(--card-bg);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.view-btn.active{background:var(--primary);border-color:var(--primary)}
.view-btn.active svg path{stroke:#fff}
.view-btn svg path{stroke:var(--text-muted)}
/* Mobile filter bar */
.mobile-filter-bar{display:none;gap:.5rem;overflow-x:auto;padding:.75rem 1rem;margin:0 -1rem;scrollbar-width:none}
.mobile-filter-bar::-webkit-scrollbar{display:none}
.mobile-filter-chip{flex-shrink:0;background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all .15s}
.mobile-filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* ── PRODUCT GRID ── */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem}
.products-grid.list-view{grid-template-columns:1fr}

/* ── PRODUCT CARD ── */
.product-card{
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:transform .2s,box-shadow .2s,border-color .2s;
  animation:fadeUp .4s ease both;position:relative;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:var(--border-strong)}
.product-card.list-view{display:flex;align-items:stretch}
.product-card.list-view .card-image{width:130px;flex-shrink:0;border-radius:0;aspect-ratio:auto}
.product-card.list-view .card-body{flex:1;display:flex;align-items:center;gap:1rem;padding:1rem}
.product-card.list-view .card-name{flex:1;margin-bottom:0;min-height:auto;font-size:14px}
.product-card.list-view .card-sku-price{margin-top:0;padding-top:0;border:none;flex-shrink:0;text-align:right}
.card-image{aspect-ratio:1;background:var(--off-white);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.card-image-pattern{position:absolute;inset:0;background-image:radial-gradient(circle, var(--border) 1px, transparent 1px);background-size:20px 20px;opacity:.5}
.card-image-icon{position:relative;z-index:1}
.card-image-icon svg{width:64px;height:64px;opacity:.18}
.product-badge{position:absolute;top:10px;left:10px;font-family:var(--font-display);font-weight:700;font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:5px}
.badge-agotado{background:rgba(232,34,42,.12);color:var(--accent);border:1px solid rgba(232,34,42,.25)}
.badge-nuevo{background:rgba(15,28,111,.1);color:var(--primary);border:1px solid rgba(15,28,111,.2)}
.badge-oferta{background:var(--gold);color:#fff}
.cat-pill{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.06);color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:20px}
.card-body{padding:1rem}
.card-sku{font-size:10px;font-weight:600;color:var(--primary-mid);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3rem;font-family:var(--font-display)}
.card-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:.4rem;min-height:38px}
.card-compat{font-size:11px;color:var(--text-light);margin-bottom:.6rem}
.card-sku-price{display:flex;align-items:center;justify-content:space-between;padding-top:.65rem;border-top:1px solid var(--border);margin-top:.4rem}
.card-price{font-family:var(--font-display);font-weight:900;font-size:22px;color:var(--primary);line-height:1}
.card-price.free{font-size:14px;color:var(--text-muted)}
.card-price sup{font-size:12px;vertical-align:super}
.add-btn{background:var(--primary);color:#fff;border:none;border-radius:7px;padding:8px 13px;cursor:pointer;font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;transition:all .15s;display:flex;align-items:center;gap:.3rem}
.add-btn:hover{background:var(--primary-mid);transform:scale(1.03)}
.add-btn.added{background:#16a34a}
.add-btn.out{background:var(--off-white);color:var(--text-light);cursor:not-allowed}
.add-btn.out:hover{transform:none}

/* ── EMPTY STATE ── */
.empty-state{grid-column:1/-1;text-align:center;padding:3.5rem 1.5rem}
.empty-icon{font-size:44px;margin-bottom:.75rem;opacity:.4}
.empty-title{font-family:var(--font-display);font-weight:800;font-size:20px;color:var(--primary);margin-bottom:.4rem;text-transform:uppercase}
.empty-sub{font-size:13px;color:var(--text-muted)}

/* ── PAGINATION ── */
.pagination{display:flex;justify-content:center;align-items:center;gap:.35rem;margin-top:1.75rem;flex-wrap:wrap}
.page-btn{width:36px;height:36px;border-radius:8px;background:var(--card-bg);border:1px solid var(--border);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-muted);transition:all .15s;display:flex;align-items:center;justify-content:center}
.page-btn:hover{border-color:var(--primary);color:var(--primary)}
.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.page-btn.dots{cursor:default;border:none;background:transparent}

/* ── TOAST ── */
.toast{
  position:fixed;z-index:400;
  background:var(--text);color:#fff;
  border-radius:10px;padding:11px 16px;
  font-size:13px;font-weight:500;
  display:flex;align-items:center;gap:.4rem;
  transform:translateY(20px);opacity:0;pointer-events:none;
  transition:all .3s;box-shadow:0 4px 20px rgba(0,0,0,.2);
  bottom:calc(var(--mobile-nav-h) + var(--safe-bottom) + 12px);
  right:16px;left:16px;
}
@media(min-width:769px){
  .toast{left:auto;right:28px;bottom:28px;max-width:320px}
}
.toast.show{transform:translateY(0);opacity:1}
.toast-icon{color:#4ade80;font-size:15px}

/* ── FOOTER ── */
.site-footer{background:var(--primary-dark);border-top:3px solid var(--accent);padding:2.5rem 1.5rem 1.5rem;margin-top:0rem}
.footer-inner{max-width:1320px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:2rem;margin-bottom:2rem}
.footer-brand .footer-logo{font-family:var(--font-display);font-weight:900;font-size:24px;color:#fff;letter-spacing:-.01em;margin-bottom:.4rem}
.footer-brand .footer-logo span{color:var(--accent-light)}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.7;max-width:240px}
.footer-social{display:flex;gap:.4rem;margin-top:.75rem}
.social-btn{width:32px;height:32px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;transition:all .15s;text-decoration:none}
.social-btn:hover{background:var(--accent);border-color:var(--accent)}
.footer-col-title{font-family:var(--font-display);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:.75rem}
.footer-links{display:flex;flex-direction:column;gap:.4rem}
.footer-links a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:#fff}
.contact-item{display:flex;align-items:flex-start;gap:.5rem;font-size:12px;color:rgba(255,255,255,.45);margin-bottom:.5rem}
.contact-icon{font-size:13px;flex-shrink:0;margin-top:1px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.25rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem}
.footer-copy{font-size:11px;color:rgba(255,255,255,.3)}
.footer-copy span{color:var(--accent-light)}
.footer-badges{display:flex;gap:.4rem}
.footer-badge{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:5px;padding:3px 9px;font-size:10px;color:rgba(255,255,255,.35);font-weight:500;letter-spacing:.04em}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}
@media(max-width:900px){.sidebar{display:none}.main-wrap{padding:1.25rem 1rem}}
@media(max-width:768px){
  .site-header{display:none}
  .mobile-top-bar{display:flex}
  .bottom-nav{display:flex}
  .mobile-filter-bar{display:flex}
  .hero{padding:2rem 1rem 1.75rem}
  .hero-stats{gap:1.25rem}
  .hero-ctas{gap:.5rem}
  .cta-primary,.cta-secondary{padding:10px 18px;font-size:13px}
  .footer-grid{grid-template-columns:1fr}
  .products-grid{grid-template-columns:1fr 1fr}
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar-left,.toolbar-right{justify-content:space-between}
  .main-wrap{padding:0 1rem 1rem}
}
@media(max-width:420px){.products-grid{grid-template-columns:1fr}}