/* ============================================================
   3D Team Brasil — Catálogo
   ============================================================ */

/* ── Banner / Hero do catálogo ──────────────────────────────── */
.catalog-hero {
  position: relative;
  padding: 4rem 0 3rem;
  background: linear-gradient(135deg, rgba(10,15,30,.95) 0%, rgba(20,30,60,.9) 100%);
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.catalog-hero__bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 20% 50%, rgba(255,107,0,.12) 0%, transparent 55%),
                    radial-gradient(circle at 80% 30%, rgba(0,212,255,.10) 0%, transparent 50%);
  pointer-events: none;
}
.catalog-hero__inner { position: relative; z-index: 1; text-align: center; }
.catalog-hero__eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .75rem; text-transform: uppercase; letter-spacing: .12em;
  color: var(--color-accent, #ff6b00); margin-bottom: .8rem;
}
.catalog-hero h1 { font-size: clamp(1.8rem, 4vw, 3rem); color: #fff; margin-bottom: .5rem; }
.catalog-hero__sub { color: #8899aa; font-size: 1rem; max-width: 500px; margin: 0 auto; }

/* ── Categoria vertical na sidebar ──────────────────────────── */
.cat-nav { display: flex; flex-direction: column; gap: .2rem; }

.cat-tab {
  display: flex; align-items: center; gap: .55rem;
  padding: .55rem .75rem; border-radius: 10px;
  font-size: .84rem; font-weight: 500; text-decoration: none;
  color: #b0bcc8;
  border: 1px solid transparent;
  transition: background .18s, color .18s, border-color .18s;
}
.cat-tab:hover {
  background: rgba(255,107,0,.1); color: #fff;
  border-color: rgba(255,107,0,.2);
}
.cat-tab.is-active {
  background: rgba(255,107,0,.18);
  color: #ff8c00; font-weight: 600;
  border-color: rgba(255,107,0,.35);
}
.cat-tab__icon { font-size: 1.05rem; width: 22px; text-align: center; flex-shrink: 0; }
.cat-tab__label { flex: 1; }
.cat-tab__count {
  font-size: .7rem; color: #6b7280;
  background: rgba(255,255,255,.07);
  border-radius: 999px; padding: .1rem .45rem;
  flex-shrink: 0;
}
.cat-tab.is-active .cat-tab__count { background: rgba(255,107,0,.2); color: #ffb07a; }

/* ── Layout principal ───────────────────────────────────────── */
.catalog-main { padding: 2rem 0 5rem; }
.catalog-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 2rem;
  align-items: start;
}
@media (max-width: 860px) { .catalog-layout { grid-template-columns: 1fr; } }

/* ── Sidebar de filtros ─────────────────────────────────────── */
.catalog-sidebar {
  position: relative; top: 120px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; padding: 1.4rem;
}
.catalog-sidebar h3 {
  font-size: .7rem; text-transform: uppercase; letter-spacing: .1em;
  color: var(--color-accent, #ff6b00); margin-bottom: .9rem; margin-top: 1.2rem;
}
.catalog-sidebar h3:first-child { margin-top: 0; }

.filter-group { margin-bottom: .4rem; }

/* Range presets */
.price-presets { display: flex; flex-wrap: wrap; gap: .35rem; margin-bottom: .6rem; }
.price-preset {
  padding: .28rem .65rem; border-radius: 6px; font-size: .75rem; cursor: pointer;
  background: rgba(255,255,255,.05); color: #c0cce0;
  border: 1px solid rgba(255,255,255,.09);
  transition: background .15s, color .15s; white-space: nowrap;
}
.price-preset:hover, .price-preset.is-active { background: rgba(255,107,0,.2); color: #ff8c00; border-color: rgba(255,107,0,.4); }

.price-range-inputs { display: flex; gap: .4rem; align-items: center; }
.price-range-inputs input {
  width: 0; flex: 1; padding: .4rem .5rem;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px; color: #fff; font-size: .8rem;
}
.price-range-inputs input:focus { outline: none; border-color: var(--color-accent,#ff6b00); }

/* Material checkboxes */
.material-list { display: flex; flex-direction: column; gap: .4rem; }
.material-item { display: flex; align-items: center; gap: .5rem; cursor: pointer; font-size: .83rem; color: #b0bcc8; }
.material-item input[type=checkbox] { accent-color: #ff6b00; }
.material-item:hover { color: #fff; }

/* Botão aplicar */
.filter-apply-btn {
  width: 100%; margin-top: 1.2rem; padding: .65rem;
  background: linear-gradient(135deg,#ff6b00,#ff8c00);
  border: none; border-radius: 10px; color: #fff;
  font-size: .9rem; font-weight: 700; cursor: pointer;
  transition: opacity .2s, transform .15s;
}
.filter-apply-btn:hover { opacity: .9; transform: translateY(-1px); }

.filter-clear-link {
  display: block; text-align: center; margin-top: .6rem;
  font-size: .78rem; color: #6b7280; text-decoration: none;
}
.filter-clear-link:hover { color: #ef4444; }

/* ── Toolbar / Ordenação ────────────────────────────────────── */
.catalog-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .8rem; margin-bottom: 1.5rem;
}
.catalog-toolbar__count { font-size: .875rem; color: #8899aa; }
.catalog-toolbar__count strong { color: #fff; }

.sort-select {
  padding: .45rem .85rem; border-radius: 8px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: #fff; font-size: .85rem; cursor: pointer;
}
.sort-select:focus { outline: none; border-color: var(--color-accent,#ff6b00); }

/* ── Active filter chips ────────────────────────────────────── */
.active-filters { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.2rem; }
.filter-chip {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .3rem .7rem; border-radius: 999px; font-size: .78rem;
  background: rgba(255,107,0,.12); border: 1px solid rgba(255,107,0,.3); color: #ffb07a;
  text-decoration: none;
}
.filter-chip i { font-size: .7rem; }
.filter-chip:hover { background: rgba(239,68,68,.15); border-color: rgba(239,68,68,.35); color: #fca5a5; }

/* ── Grid de produtos ───────────────────────────────────────── */
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.4rem;
}

/* ── Product card no catálogo ───────────────────────────────── */
.catalog-grid .product-card {
  display: flex;
  flex-direction: column;
}
.catalog-grid .product-card__body {
  flex: 1;
}

/* ── Imagem: garante que preencha o image-wrap corretamente ── */
.catalog-grid .product-card__image-wrap > a {
  display: block;
  width: 100%;
  height: 100%;
}
.catalog-grid .product-card__image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.catalog-grid .product-card:hover .product-card__image-wrap img {
  transform: scale(1.06);
}

/* Área de ações */
.catalog-grid .product-card__actions {
  padding: 0 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

/* Botão carrinho — largura total */
.catalog-grid .product-card__actions .add-to-cart {
  width: 100%;
  justify-content: center;
  gap: .4rem;
  padding: .6rem 1rem;
  font-size: .85rem;
}

/* Segunda linha: Ver Detalhes + coração */
.catalog-grid .product-card__actions-row {
  display: flex;
  gap: .4rem;
  align-items: stretch;
}

/* "Ver Detalhes" ocupa o espaço restante */
.catalog-grid .product-card__actions-row .btn--outline {
  flex: 1;
  justify-content: center;
  gap: .35rem;
  font-size: .8rem;
  padding: .45rem .6rem;
  white-space: nowrap;
}

/* Botão coração — quadrado, tamanho fixo */
.catalog-grid .product-card__wish-btn {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.04);
  color: #6b7280;
  cursor: pointer;
  transition: color .2s, border-color .2s, background .2s;
  padding: 0;
}
.catalog-grid .product-card__wish-btn:hover,
.catalog-grid .product-card__wish-btn.is-active {
  border-color: #ef4444;
  color: #ef4444;
  background: rgba(239,68,68,.08);
}

/* ── Estado vazio ───────────────────────────────────────────── */
.catalog-empty {
  text-align: center; padding: 4rem 1rem;
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
}
.catalog-empty__icon { font-size: 3.5rem; opacity: .25; }
.catalog-empty h2 { font-size: 1.3rem; color: #fff; }
.catalog-empty p { color: #8899aa; max-width: 340px; }

/* ── Paginação ──────────────────────────────────────────────── */
.catalog-pagination {
  display: flex; justify-content: center; align-items: center;
  gap: .4rem; margin-top: 2.5rem; flex-wrap: wrap;
}
.page-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 38px; height: 38px; padding: 0 .8rem; border-radius: 8px;
  font-size: .875rem; text-decoration: none; font-weight: 500;
  background: rgba(255,255,255,.05); color: #c0cce0;
  border: 1px solid rgba(255,255,255,.08);
  transition: background .2s, color .2s;
}
.page-btn:hover { background: rgba(255,107,0,.18); color: #fff; }
.page-btn.is-active { background: linear-gradient(135deg,#ff6b00,#ff8c00); color: #fff; border-color: transparent; }
.page-btn[aria-disabled="true"] { opacity: .35; pointer-events: none; }
