:root {
  --nm-black: #050505;
  --nm-ink: #101410;
  --nm-muted: #66706A;
  --nm-green: #00E676;
  --nm-green-dark: #00B85C;
  --nm-green-soft: #E9FFF3;
  --nm-paper: #F6F8F6;
  --nm-line: #DDE8E0;
  --nm-white: #FFFFFF;
  --nm-shadow: 0 10px 28px rgba(5, 5, 5, .07);
  --nm-shadow-hover: 0 16px 38px rgba(5, 5, 5, .10);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
html, body { min-height: 100%; }
body {
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--nm-paper);
  color: var(--nm-ink);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select { font-family: inherit; }
.container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }

.site-header { position: sticky; top: 0; z-index: 80; background: var(--nm-black); color: var(--nm-white); border-bottom: 0; box-shadow: none; }
.header-row { min-height: 64px; display: grid; grid-template-columns: 160px 170px minmax(280px, 1fr) auto; gap: 16px; align-items: center; }
.brand { min-height: 50px; display: inline-flex; align-items: center; justify-content: center; border-radius: 10px; padding: 8px 14px; background: var(--nm-white); border: 1px solid var(--nm-white); }
.brand:hover { border-color: var(--nm-green); }
.brand img { height: 40px; width: auto; object-fit: contain; }
.brand-text { display: none; }
.deliver-to, .header-link { min-height: 46px; display: inline-flex; align-items: center; gap: 9px; padding: 8px 11px; border-radius: 10px; background: #101410; border: 1px solid #26352D; color: var(--nm-white); font-size: 12.5px; font-weight: 850; }
.deliver-to i { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 12px; background: rgba(0, 230, 118, .14); color: var(--nm-green); }
.deliver-to small, .header-link small { display: block; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 750; line-height: 1; margin-bottom: 4px; }
.deliver-to b { display: block; max-width: 118px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--nm-white); }
.search { height: 48px; display: flex; align-items: stretch; overflow: hidden; background: var(--nm-white); border: 2px solid var(--nm-green); border-radius: 10px; box-shadow: 0 14px 30px rgba(5,5,5,.16); }
.search:focus-within { box-shadow: 0 0 0 4px rgba(0,230,118,.18), 0 14px 30px rgba(5,5,5,.16); }
.search .search-cat { max-width: 150px; border: 0; border-right: 1px solid var(--nm-line); background: #F8FBF9; color: var(--nm-black); padding: 0 30px 0 12px; font-size: 12px; font-weight: 850; outline: 0; }
.search input { flex: 1; min-width: 0; border: 0; outline: 0; padding: 0 15px; color: var(--nm-black); font-size: 14px; font-weight: 600; }
.search input::placeholder { color: #9AA8A0; }
.search button { width: 52px; border: 0; border-left: 1px solid var(--nm-line); background: var(--nm-white); color: var(--nm-black); font-size: 18px; cursor: pointer; }
.search button:hover { background: var(--nm-green-soft); }
.header-actions { display: flex; align-items: center; gap: 8px; white-space: nowrap; }
.header-cta { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 0 16px; border-radius: 10px; background: var(--nm-green); color: #031108; font-weight: 950; font-size: 13px; box-shadow: 0 12px 26px rgba(0,230,118,.20); }
.header-cta:hover { background: var(--nm-green-dark); transform: translateY(-1px); }
.subnav { background: var(--nm-black); border-top: 0; }
.subnav-row { min-height: 42px; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 7px 0; font-size: 12.5px; font-weight: 850; }
.subnav-row a { position: relative; display: inline-flex; align-items: center; gap: 7px; color: rgba(255,255,255,.82); padding: 7px 11px; border-radius: 10px; }
.subnav-row a::after { content: ''; position: absolute; left: 12px; right: 12px; bottom: 3px; height: 2px; border-radius: 10px; background: var(--nm-green); transform: scaleX(0); transition: transform .2s ease; }
.subnav-row a:hover, .subnav-row a.active { color: var(--nm-white); background: rgba(255,255,255,.06); }
.subnav-row a:hover::after, .subnav-row a.active::after { transform: scaleX(1); }

.hero { margin-top: 0; padding: 0 0 18px; background: var(--nm-black); }
.hero-card { min-height: 210px; display: grid; grid-template-columns: minmax(0, 1fr) 230px; gap: 20px; align-items: center; padding: 30px 0 32px; border-radius: 0; background: var(--nm-black); color: var(--nm-white); box-shadow: none; }
.hero-eyebrow { width: fit-content; display: inline-flex; align-items: center; gap: 8px; margin-bottom: 12px; padding: 7px 12px; border-radius: 10px; background: rgba(0,230,118,.13); border: 1px solid rgba(0,230,118,.26); color: #B8F7D0; font-size: 10.5px; font-weight: 950; letter-spacing: .11em; text-transform: uppercase; }
.hero-eyebrow::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--nm-green); box-shadow: 0 0 0 5px rgba(0,230,118,.14); }
.hero-card h1 { max-width: 780px; margin-bottom: 12px; color: var(--nm-white); font-size: clamp(30px, 4vw, 52px); line-height: 1; letter-spacing: -.06em; font-weight: 950; }
.hero-card h1 mark { background: var(--nm-green); color: #031108; border-radius: 12px; padding: 0 .12em; box-decoration-break: clone; -webkit-box-decoration-break: clone; }
.hero-card p { max-width: 680px; color: rgba(255,255,255,.76); font-size: 15px; line-height: 1.65; margin-bottom: 16px; }
.hero-stats { display: flex; gap: 9px; flex-wrap: wrap; }
.hero-stat { display: inline-flex; align-items: center; gap: 8px; padding: 8px 11px; border-radius: 14px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.82); font-size: 12px; font-weight: 850; }
.hero-stat i { color: var(--nm-green); }
.hero-stat b { color: var(--nm-white); }
.hero-cta-area { display: flex; flex-direction: column; gap: 10px; justify-self: end; width: min(230px, 100%); }
.hero-cta, .hero-cta-ghost { min-height: 46px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 10px; font-size: 13px; font-weight: 950; }
.hero-cta { background: var(--nm-green); color: #031108; }
.hero-cta:hover { background: var(--nm-green-dark); transform: translateY(-1px); }
.hero-cta-ghost { background: rgba(255,255,255,.08); color: var(--nm-white); border: 1px solid rgba(255,255,255,.16); }
.hero-cta-ghost:hover { background: rgba(255,255,255,.14); }

.marketplace-section { margin-top: 18px; }
.marketplace-section-head { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; margin-bottom: 12px; }
.marketplace-section-title { display: flex; align-items: center; gap: 8px; color: var(--nm-black); font-size: 18px; font-weight: 950; letter-spacing: -.04em; }
.marketplace-section-title i { color: var(--nm-green-dark); }
.marketplace-section-caption { color: var(--nm-muted); font-weight: 750; }
.estados-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 12px; margin: 8px 0 22px; }
.estado-tile, .side-card, .side-cta, .results-bar, .card, .gallery, .info-card, .seller-card, .description, .empty { background: var(--nm-white); border: 1px solid var(--nm-line); border-radius: 10px; box-shadow: var(--nm-shadow); }
.estado-tile { display: flex; align-items: center; gap: 13px; padding: 15px; transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease; }
.estado-tile:hover, .card:hover { transform: translateY(-4px); border-color: #B8F7D0; box-shadow: var(--nm-shadow-hover); }
.estado-icon, .side-title i, .empty-icon { width: 44px; height: 44px; display: grid; place-items: center; border-radius: 10px; background: var(--nm-green-soft); color: var(--nm-green-dark); font-size: 18px; flex: 0 0 auto; }
.estado-tile b { display: block; color: var(--nm-black); font-weight: 950; }
.estado-tile small { color: var(--nm-muted); font-weight: 750; }

.shell { display: grid; grid-template-columns: 286px minmax(0, 1fr); gap: 18px; padding: 16px 0 58px; align-items: start; }
.sidebar { position: sticky; top: 136px; display: flex; flex-direction: column; gap: 12px; }
.side-card, .side-cta { padding: 14px; }
.side-title { display: flex; align-items: center; gap: 9px; color: var(--nm-black); font-size: 12px; font-weight: 950; letter-spacing: .07em; text-transform: uppercase; margin-bottom: 10px; }
.side-title i { width: 28px; height: 28px; font-size: 14px; border-radius: 11px; }
.side-list { list-style: none; display: grid; gap: 4px; }
.side-list a { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 13px; color: var(--nm-ink); font-size: 13px; font-weight: 800; }
.side-list a:hover, .side-list a.active { background: var(--nm-green-soft); color: #007A3D; }
.side-list .count { padding: 3px 8px; border-radius: 10px; background: #DDFEEB; color: #007A3D; font-size: 11px; font-weight: 950; }
.side-cta { background: var(--nm-black); color: var(--nm-white); border-color: rgba(0,230,118,.18); }
.side-cta i { width: 38px; height: 38px; display: grid; place-items: center; margin-bottom: 12px; border-radius: 14px; background: rgba(0,230,118,.13); color: var(--nm-green); }
.side-cta h4 { color: var(--nm-white); font-size: 16px; margin-bottom: 7px; }
.side-cta p { color: rgba(255,255,255,.70); font-size: 13px; margin-bottom: 13px; }
.side-cta a { display: inline-flex; align-items: center; justify-content: center; min-height: 39px; padding: 0 14px; border-radius: 10px; background: var(--nm-green); color: #031108; font-weight: 950; }

.results-bar { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; padding: 18px 20px; margin-bottom: 16px; }
.crumb, .crumb-row { color: var(--nm-muted); font-size: 12px; font-weight: 750; }
.crumb a, .crumb-row a { color: var(--nm-green-dark); font-weight: 950; }
.results-title { color: var(--nm-black); font-size: 25px; font-weight: 950; letter-spacing: -.05em; }
.results-title small { display: block; color: var(--nm-muted); font-size: 13px; font-weight: 700; letter-spacing: 0; margin-top: 2px; }
.chips { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 10px; }
.chip, .cat-badge { display: inline-flex; align-items: center; gap: 7px; padding: 6px 11px; border-radius: 10px; background: var(--nm-green-soft); border: 1px solid #B8F7D0; color: #007A3D; font-size: 12px; font-weight: 950; }
.sort-form { display: flex; align-items: center; gap: 9px; color: var(--nm-muted); font-size: 12px; font-weight: 900; }
.sort-form select { height: 40px; border: 1px solid var(--nm-line); border-radius: 14px; background: var(--nm-white); color: var(--nm-black); padding: 0 32px 0 12px; font-weight: 850; }

.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(206px, 1fr)); gap: 14px; }
.card { overflow: hidden; display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.media { position: relative; aspect-ratio: 1.12 / 1; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 16px; background: #F8FBF9; }
.media img { width: 100%; height: 100%; object-fit: contain; transition: transform .24s ease; }
.card:hover .media img { transform: scale(1.035); }
.media .placeholder { font-size: 46px; color: #CBD5E1; }
.flag { position: absolute; top: 10px; left: 10px; display: inline-flex; align-items: center; gap: 5px; padding: 5px 9px; border-radius: 10px; font-size: 10px; font-weight: 950; letter-spacing: .05em; text-transform: uppercase; }
.flag-new, .flag-stock { background: #DDFEEB; color: #007A3D; }
.flag-low, .flag-stock.low { background: var(--nm-black); color: var(--nm-green); }
.flag-out, .flag-stock.out { background: var(--nm-black); color: var(--nm-white); }
.flag-feat { background: var(--nm-green); color: #031108; }
.cat-tag { position: absolute; left: 10px; bottom: 10px; max-width: calc(100% - 76px); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; padding: 5px 9px; border-radius: 10px; background: rgba(5,5,5,.84); color: var(--nm-white); font-size: 10px; font-weight: 900; }
.fav { position: absolute; top: 10px; right: 10px; width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--nm-line); background: rgba(255,255,255,.94); color: var(--nm-muted); display: grid; place-items: center; opacity: 0; transition: opacity .16s ease, transform .16s ease; }
.card:hover .fav { opacity: 1; }
.card-body { padding: 14px 15px 15px; display: flex; flex-direction: column; gap: 6px; flex: 1; border-top: 1px solid var(--nm-line); }
.store-row { display: flex; align-items: center; gap: 8px; color: var(--nm-muted); font-size: 11px; font-weight: 800; min-width: 0; }
.store-logo { width: 24px; height: 24px; border-radius: 9px; background: #F8FBF9; border: 1px solid var(--nm-line); display: grid; place-items: center; overflow: hidden; flex: 0 0 auto; }
.store-logo img { width: 100%; height: 100%; object-fit: cover; }
.store-logo i, .location-mini i { color: var(--nm-green-dark); }
.store-name { color: var(--nm-black); font-weight: 950; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.location-mini { max-width: 96px; display: inline-flex; align-items: center; gap: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--nm-muted); font-size: 10.5px; }
.prod-name { min-height: 40px; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; color: var(--nm-black); font-size: 14px; line-height: 1.35; font-weight: 850; letter-spacing: -.01em; }
.prod-name:hover { color: var(--nm-green-dark); }
.prod-desc { display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 34px; color: var(--nm-muted); font-size: 12px; line-height: 1.38; }
.rating { display: inline-flex; align-items: center; gap: 7px; color: var(--nm-green-dark); font-size: 12px; font-weight: 800; }
.rating .stars { color: #F59E0B; }
.rating .count { color: var(--nm-muted); font-size: 11px; }
.price-block { margin-top: 5px; padding-top: 8px; border-top: 1px dashed var(--nm-line); }
.price-main { display: flex; align-items: baseline; gap: 2px; color: var(--nm-black); }
.price-main .currency { font-size: 14px; font-weight: 950; }
.price-main .amount { font-size: 27px; font-weight: 950; line-height: 1; letter-spacing: -.04em; }
.price-main.agotado { opacity: .46; text-decoration: line-through; }
.price-bs { margin-top: 4px; color: var(--nm-muted); font-size: 11.5px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.shipping { margin-top: 5px; color: var(--nm-green-dark); font-size: 11.5px; font-weight: 800; line-height: 1.3; }
.shipping b { color: var(--nm-black); }
.stock-line { display: inline-flex; align-items: center; gap: 6px; margin-top: 5px; font-size: 11.5px; font-weight: 850; }
.stock-line.ok { color: var(--nm-green-dark); }
.stock-line.warn { color: #B45309; }
.stock-line.out { color: var(--nm-muted); }
.actions { display: grid; grid-template-columns: 1fr 38px; gap: 7px; margin-top: auto; padding-top: 10px; }
.btn, .seller-link { display: inline-flex; align-items: center; justify-content: center; gap: 7px; height: 40px; padding: 0 13px; border-radius: 14px; border: 1px solid transparent; font-size: 12.5px; font-weight: 950; cursor: pointer; transition: transform .16s ease, background .16s ease, color .16s ease, border-color .16s ease; }
.btn:hover, .seller-link:hover { transform: translateY(-1px); }
.btn-primary { background: var(--nm-black); color: var(--nm-white); border-color: var(--nm-black); }
.btn-primary:hover { background: #101410; }
.btn-wa, .seller-link.wa { width: 40px; padding: 0; background: var(--nm-green); color: #031108; border-color: var(--nm-green); font-size: 16px; }
.btn-ghost, .seller-link { background: var(--nm-white); color: var(--nm-black); border-color: var(--nm-line); }
.btn-ghost:hover, .seller-link:hover { border-color: var(--nm-green); }
.empty { padding: 64px 28px; text-align: center; }
.empty-icon { width: 76px; height: 76px; margin: 0 auto 16px; font-size: 32px; }
.empty h3 { color: var(--nm-black); font-size: 24px; font-weight: 950; margin-bottom: 8px; }
.empty p { color: var(--nm-muted); max-width: 520px; margin: 0 auto 20px; }
.pagination { display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; margin-top: 32px; }
.page-link { min-width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; padding: 0 14px; border-radius: 14px; background: var(--nm-white); border: 1px solid var(--nm-line); color: var(--nm-muted); font-weight: 950; }
.page-link:hover, .page-link.active { background: var(--nm-black); border-color: var(--nm-black); color: var(--nm-white); }
.page-link.disabled { opacity: .45; pointer-events: none; }

.crumb-row { padding: 18px 0 4px; display: flex; flex-wrap: wrap; align-items: center; gap: 5px; }
.layout { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr); gap: 22px; padding: 14px 0 34px; align-items: start; }
.gallery { position: sticky; top: 110px; padding: 18px; }
.main-img { position: relative; aspect-ratio: 1 / 1; border-radius: 22px; background: #F8FBF9; overflow: hidden; display: grid; place-items: center; }
.main-img img { width: 100%; height: 100%; object-fit: contain; padding: 18px; }
.main-img .ph { font-size: 84px; color: #CBD5E1; }
.flag.right { left: auto; right: 14px; }
.flag-cat { background: var(--nm-black); color: var(--nm-white); }
.thumbs { display: grid; grid-template-columns: repeat(auto-fill, minmax(64px, 1fr)); gap: 10px; margin-top: 14px; }
.thumb { aspect-ratio: 1 / 1; overflow: hidden; border: 2px solid var(--nm-line); border-radius: 14px; background: #F8FBF9; cursor: pointer; }
.thumb img { width: 100%; height: 100%; object-fit: cover; }
.thumb.active, .thumb:hover { border-color: var(--nm-green); }
.info { display: flex; flex-direction: column; gap: 14px; }
.info-card, .seller-card, .description { padding: 24px; }
.title { color: var(--nm-black); font-size: clamp(24px, 3vw, 34px); line-height: 1.12; letter-spacing: -.05em; font-weight: 950; margin-bottom: 8px; }
.subtitle { display: flex; flex-wrap: wrap; gap: 12px; padding-bottom: 16px; margin-bottom: 18px; border-bottom: 1px solid var(--nm-line); color: var(--nm-muted); font-size: 13px; font-weight: 750; }
.subtitle i { color: var(--nm-green-dark); margin-right: 4px; }
.price-row { display: flex; align-items: baseline; gap: 6px; color: var(--nm-black); }
.price-row .currency { font-size: 18px; font-weight: 800; }
.price-row .amount { font-size: 46px; font-weight: 950; letter-spacing: -.06em; line-height: 1; }
.price-note { color: var(--nm-muted); font-size: 12px; margin-top: 4px; }
.stock-bar { display: flex; align-items: center; gap: 10px; margin-top: 18px; padding: 12px 14px; border-radius: 10px; background: var(--nm-green-soft); border: 1px solid #B8F7D0; color: #166534; font-weight: 850; }
.stock-bar.low { background: #FFFBEB; border-color: #FDE68A; color: #92400E; }
.stock-bar.out { background: #FEF2F2; border-color: #FECACA; color: #991B1B; }
.variants { margin-top: 18px; padding: 18px; background: #F8FBF9; border: 1px solid var(--nm-line); border-radius: 20px; }
.variants-title { color: var(--nm-muted); font-size: 11px; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 12px; }
.var-list { display: flex; flex-wrap: wrap; gap: 8px; }
.var-btn { padding: 9px 13px; background: var(--nm-white); color: var(--nm-black); border: 1px solid var(--nm-line); border-radius: 14px; font-weight: 850; cursor: pointer; }
.var-btn:hover:not(:disabled), .var-btn.selected { border-color: var(--nm-green); background: var(--nm-green-soft); color: #007A3D; }
.var-btn:disabled { opacity: .45; cursor: not-allowed; text-decoration: line-through; }
.var-btn small { font-size: 10.5px; color: var(--nm-muted); }
.var-status { margin-top: 10px; color: var(--nm-muted); font-size: 12px; font-weight: 750; }
.var-color-dot { display: inline-block; width: 14px; height: 14px; border-radius: 50%; background: var(--variant-color, #CBD5E1); border: 1px solid rgba(15,23,42,.22); }
.var-out { color: #DC2626 !important; }
.seller-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.seller-logo { width: 56px; height: 56px; border-radius: 10px; background: #F8FBF9; border: 1px solid var(--nm-line); overflow: hidden; display: grid; place-items: center; flex: 0 0 auto; }
.seller-logo img { width: 100%; height: 100%; object-fit: cover; }
.seller-logo i { color: var(--nm-muted); font-size: 24px; }
.seller-name { color: var(--nm-black); font-size: 17px; font-weight: 950; }
.seller-meta { color: var(--nm-muted); font-size: 12.5px; font-weight: 750; }
.seller-meta i { color: var(--nm-green-dark); }
.seller-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 14px; }
.seller-stat { padding: 11px 12px; border-radius: 10px; background: #F8FBF9; border: 1px solid var(--nm-line); }
.seller-stat small { display: block; color: var(--nm-muted); font-size: 10.5px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; }
.seller-stat b { color: var(--nm-black); font-size: 13px; }
.seller-stat-wide { grid-column: 1 / -1; }
.seller-actions { display: grid; gap: 8px; }
.seller-link.wa { width: auto; color: #031108; }
.description { margin-top: 6px; }
.description h2 { display: flex; align-items: center; gap: 8px; color: var(--nm-black); font-size: 19px; font-weight: 950; margin-bottom: 14px; }
.description h2 i { color: var(--nm-green-dark); }
.description-body { color: var(--nm-muted); font-size: 14.5px; line-height: 1.75; white-space: pre-wrap; }
.description-empty { font-style: italic; }
.back-to-top { display: block; padding: 15px; background: var(--nm-black); color: var(--nm-white); text-align: center; font-size: 13px; font-weight: 900; }
.site-footer { margin-top: 0; padding: 38px 0 22px; background: var(--nm-black); color: rgba(255,255,255,.72); border-top: 3px solid var(--nm-green); }
.site-footer .container { display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: center; }
.footer-brand { color: var(--nm-white); font-size: 17px; font-weight: 950; }
.footer-links { display: flex; justify-content: center; gap: 18px; flex-wrap: wrap; }
.footer-links a { color: rgba(255,255,255,.72); font-weight: 850; }
.footer-links a:hover { color: var(--nm-green); }
.footer-copy { color: rgba(255,255,255,.48); text-align: right; font-size: 12px; font-weight: 750; }

@media (max-width: 1080px) {
  .header-row { grid-template-columns: auto 1fr auto; }
  .deliver-to { display: none; }
  .search { grid-column: 1 / -1; order: 3; }
  .shell, .layout { grid-template-columns: 1fr; }
  .sidebar { position: static; display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
  .gallery { position: static; }
  .hero-card { grid-template-columns: 1fr; }
  .hero-cta-area { justify-self: start; flex-direction: row; width: auto; }
  .grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}

@media (max-width: 720px) {
  .container { padding: 0 16px; }
  .header-row { grid-template-columns: 1fr auto; gap: 10px; padding: 12px 0; }
  .brand { width: max-content; }
  .brand img { height: 36px; }
  .header-actions .header-link { display: none; }
  .search { height: 46px; }
  .search .search-cat { display: none; }
  .subnav-row { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 10px; }
  .subnav-row a { white-space: nowrap; }
  .hero { padding-top: 18px; }
  .hero-card { padding: 24px 0 26px; border-radius: 0; }
  .hero-card h1 { font-size: 32px; }
  .hero-card p { font-size: 14px; }
  .hero-cta-area { flex-direction: column; width: 100%; }
  .hero-cta, .hero-cta-ghost { width: 100%; }
  .results-bar { flex-direction: column; align-items: stretch; }
  .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .media { padding: 12px; }
  .card-body { padding: 12px; }
  .prod-name { font-size: 13px; }
  .price-main .amount { font-size: 23px; }
  .location-mini { display: none; }
  .actions { grid-template-columns: 1fr; }
  .btn-wa, .btn-ghost { width: 100%; }
  .seller-stats { grid-template-columns: 1fr; }
  .site-footer .container { grid-template-columns: 1fr; text-align: center; }
  .footer-links { justify-content: center; }
  .footer-copy { text-align: center; }
}

@media (max-width: 420px) {
  .grid { grid-template-columns: 1fr; }
  .hero-stats { display: grid; }
}

.category-showcase { display: grid; grid-template-columns: repeat(auto-fill, minmax(176px, 1fr)); gap: 10px; }
.category-tile { display: flex; align-items: center; gap: 10px; min-height: 58px; padding: 11px 12px; background: var(--nm-white); border: 1px solid var(--nm-line); border-radius: 10px; box-shadow: var(--nm-shadow); }
.category-tile:hover, .category-tile.active { border-color: var(--nm-green); background: var(--nm-green-soft); color: #007A3D; }
.category-tile i { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; background: var(--nm-black); color: var(--nm-green); flex: 0 0 auto; }
.category-tile b { display: block; color: var(--nm-black); font-size: 13px; line-height: 1.15; }
.category-tile small { color: var(--nm-muted); font-size: 11px; font-weight: 800; }
.side-list--dense { max-height: none; overflow: visible; }
.side-list details { border-top: 1px solid var(--nm-line); padding: 5px 0; }
.side-list details:first-child { border-top: 0; }
.side-list summary { cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: 8px; padding: 8px 10px; border-radius: 8px; color: var(--nm-black); font-size: 13px; font-weight: 900; }
.side-list summary::-webkit-details-marker { display: none; }
.side-list summary:hover { background: var(--nm-green-soft); color: #007A3D; }
.side-subcats { display: grid; gap: 2px; padding: 2px 0 6px 12px; }
.side-subcats a { font-size: 12px; font-weight: 750; padding: 6px 8px; }
.market-dropdown { background: var(--nm-white); border: 1px solid var(--nm-line); border-radius: 10px; box-shadow: var(--nm-shadow); overflow: hidden; }
.market-dropdown > summary { min-height: 54px; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 16px; cursor: pointer; list-style: none; }
.market-dropdown > summary::-webkit-details-marker { display: none; }
.market-dropdown > summary::after { content: '\F282'; font-family: 'bootstrap-icons'; width: 30px; height: 30px; display: grid; place-items: center; flex: 0 0 auto; border-radius: 9px; background: var(--nm-green-soft); color: var(--nm-green-dark); font-size: 14px; transition: transform .18s ease; }
.market-dropdown[open] > summary { border-bottom: 1px solid var(--nm-line); }
.market-dropdown[open] > summary::after { transform: rotate(180deg); }
.market-dropdown .category-showcase, .market-dropdown .estados-grid { padding: 14px; margin: 0; }
.estado-tile.active { border-color: var(--nm-green); background: var(--nm-green-soft); color: #007A3D; }
.side-dropdown > summary.side-title { position: relative; margin-bottom: 0; padding-right: 34px; cursor: pointer; list-style: none; }
.side-dropdown > summary.side-title::-webkit-details-marker { display: none; }
.side-dropdown > summary.side-title::after { content: '\F282'; font-family: 'bootstrap-icons'; position: absolute; right: 0; top: 50%; width: 28px; height: 28px; display: grid; place-items: center; border-radius: 9px; background: var(--nm-green-soft); color: var(--nm-green-dark); transform: translateY(-50%); transition: transform .18s ease; }
.side-dropdown[open] > summary.side-title { margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid var(--nm-line); }
.side-dropdown[open] > summary.side-title::after { transform: translateY(-50%) rotate(180deg); }
@media (max-width: 720px) { .category-showcase { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
