/* ── CATÁLOGO DE ANÁLISIS ──────────────────────────────── */

/* Hero */
.cat-hero {
  position: relative;
  padding: calc(var(--hh) + 56px) 0 44px;
  background:
    radial-gradient(ellipse 70% 55% at 80% 15%, rgba(124,58,237,.16), transparent 60%),
    radial-gradient(ellipse 60% 45% at 12% 95%, rgba(34,211,238,.06), transparent 60%),
    var(--bg);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.cat-hero-grain {
  position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black, transparent 80%);
}
.cat-hero-inner { position: relative; z-index: 1; }
.cat-hero .crumbs { margin-bottom: 16px; }
.cat-hero .eyebrow { display: inline-block; margin-bottom: 14px; }
.cat-title {
  font-family: 'Syne', sans-serif;
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 800; letter-spacing: -1.5px; line-height: 1.05;
  color: var(--t1); margin-bottom: 14px;
}
.cat-title em { font-style: normal; color: var(--purple-l); }
.cat-lede { font-size: 1rem; color: var(--t2); line-height: 1.7; max-width: 580px; margin-bottom: 28px; }

.cat-search {
  max-width: 640px;
  display: flex; align-items: center; gap: 10px;
  background: var(--surf); border: 1px solid var(--border);
  border-radius: 12px; padding: 12px 16px;
  transition: border-color .2s, box-shadow .2s;
}
.cat-search:focus-within { border-color: var(--purple); box-shadow: 0 0 0 3px rgba(124,58,237,.15); }
.cat-search svg { color: var(--t3); flex-shrink: 0; }
.cat-search input {
  flex: 1; background: none; color: var(--t1);
  font: .95rem 'Inter', sans-serif;
}
.cat-search input::placeholder { color: var(--t4); }
.cat-search kbd {
  padding: 2px 8px; background: var(--surf2); border: 1px solid var(--border2);
  border-radius: 4px; font-size: .68rem; color: var(--t3); font-family: ui-monospace, monospace;
}

.cat-stats {
  margin-top: 22px;
  display: flex; gap: 28px; flex-wrap: wrap;
  font-size: .82rem; color: var(--t3);
}
.cat-stats strong { color: var(--t1); font-weight: 700; }

/* ── BARRA DE FILTROS LIMPIA ─────────────────────────────── */
.cat-filters {
  position: sticky; top: var(--hh); z-index: 50;
  background: rgba(9,9,15,.92);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--border);
}
body[data-theme="light"] .cat-filters { background: rgba(255,255,255,.92); }

.cat-filter-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 14px 0;
}

.cat-fb-group { position: relative; }
.cat-fb-trigger {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 14px;
  background: var(--surf); border: 1px solid var(--border);
  border-radius: 10px;
  font: 600 .85rem 'Inter', sans-serif;
  color: var(--t1);
  transition: border-color .2s, background .2s;
  cursor: pointer;
}
.cat-fb-trigger:hover { border-color: var(--border2); background: var(--surf2); }
.cat-fb-group.open .cat-fb-trigger {
  border-color: var(--purple-l);
  background: rgba(124,58,237,.08);
}
.cat-fb-key {
  font-size: .68rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--t3);
}
.cat-fb-val { color: var(--t1); font-weight: 600; }
.cat-fb-group.active .cat-fb-val { color: var(--purple-l); }
.cat-fb-trigger svg { color: var(--t3); transition: transform .2s; }
.cat-fb-group.open .cat-fb-trigger svg { transform: rotate(180deg); color: var(--purple-l); }

.cat-fb-pop {
  position: absolute; top: calc(100% + 8px); left: 0;
  min-width: 220px; max-width: 340px;
  background: var(--surf);
  border: 1px solid var(--border2);
  border-radius: 12px;
  padding: 8px;
  box-shadow: 0 12px 40px rgba(0,0,0,.4);
  display: none;
  flex-direction: column; gap: 2px;
  z-index: 60;
}
.cat-fb-group.open .cat-fb-pop { display: flex; }
.cat-fb-pop button {
  text-align: left; padding: 8px 12px;
  border-radius: 8px;
  font: 500 .85rem 'Inter', sans-serif;
  color: var(--t2); background: transparent; border: none;
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  transition: background .15s, color .15s;
}
.cat-fb-pop button:hover { background: var(--surf2); color: var(--t1); }
.cat-fb-pop button.active {
  background: rgba(124,58,237,.14); color: var(--purple-l);
}
.cat-fb-pop button.active::after {
  content: '✓'; color: var(--purple-l); font-weight: 700;
}

.cat-fb-spacer { flex: 1; }

.cat-sort {
  display: flex; align-items: center; gap: 8px;
  background: var(--surf); border: 1px solid var(--border);
  border-radius: 10px; padding: 4px 14px;
}
.cat-sort label {
  font-size: .68rem; color: var(--t3); font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
}
.cat-sort select {
  background: none; border: none; color: var(--t1);
  font: 600 .85rem 'Inter', sans-serif;
  cursor: pointer; outline: none;
  padding: 8px 0;
}
.cat-sort select option { background: var(--surf); color: var(--t1); }

.cat-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 0 0 14px;
  border-top: 1px solid var(--border);
  margin-top: -1px; padding-top: 14px;
}
.cat-result-count { font-size: .85rem; color: var(--t2); }
.cat-result-count strong { color: var(--t1); font-weight: 700; }

.cat-clear {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; background: transparent;
  border: 1px solid var(--border2); border-radius: 8px;
  font: 600 .78rem 'Inter', sans-serif; color: var(--t2);
  transition: color .2s, border-color .2s, background .2s;
  cursor: pointer;
}
.cat-clear:hover { color: var(--t1); border-color: var(--purple-l); background: rgba(124,58,237,.08); }
.cat-clear[disabled] { opacity: .35; cursor: not-allowed; pointer-events: none; }

/* ── GRID UNIFORME ───────────────────────────────────────── */
.cat-section { padding: 36px 0 96px; }
.cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.cat-card {
  background: var(--surf); border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden; cursor: pointer;
  transition: border-color .25s, transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
}
.cat-card:hover {
  border-color: rgba(124,58,237,.45);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.4);
}

.cat-card .img-wrap { position: relative; flex-shrink: 0; }
.cat-card .img {
  width: 100%; aspect-ratio: 16/10;
  background-size: cover; background-position: center;
  background-color: var(--surf2);
  transition: transform .5s var(--ease);
}
.cat-card:hover .img { transform: scale(1.04); }
.cat-card .img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 55%, rgba(9,9,15,.85));
  pointer-events: none;
}
.cat-card .chips {
  position: absolute; top: 10px; left: 10px;
  display: flex; gap: 4px; z-index: 1;
}
.cat-card .score-dot {
  position: absolute; bottom: 10px; right: 10px; z-index: 1;
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Syne', sans-serif; font-weight: 800; font-size: .95rem;
  backdrop-filter: blur(8px); border: 1.5px solid transparent;
}
.cat-card .score-dot.score-purple { background: rgba(124,58,237,.5); border-color: rgba(167,139,250,.55); color: #fff; }
.cat-card .score-dot.score-blue   { background: rgba(96,165,250,.32); border-color: rgba(96,165,250,.5); color: var(--blue); }
.cat-card .score-dot.score-green  { background: rgba(16,185,129,.32); border-color: rgba(52,211,153,.5); color: #34d399; }
.cat-card .score-dot.score-red    { background: rgba(244,63,94,.32); border-color: rgba(244,63,94,.5); color: #fb7185; }

.cat-card .body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.cat-card .genre {
  font-size: .65rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--purple-l);
}
.cat-card h3 {
  font-family: 'Syne', sans-serif; font-size: 1.05rem; font-weight: 700;
  color: var(--t1); line-height: 1.25; letter-spacing: -.2px;
}
.cat-card .excerpt {
  font-size: .85rem; color: var(--t2); line-height: 1.55;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.cat-card .meta {
  margin-top: auto; padding-top: 12px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  font-size: .72rem; color: var(--t3);
}

/* Reveal */
.cat-card {
  opacity: 0; transform: translateY(16px);
  animation: catIn .5s var(--ease) forwards;
}
@keyframes catIn { to { opacity: 1; transform: none; } }

/* ── EMPTY STATE ─────────────────────────────────────────── */
.cat-empty {
  text-align: center; padding: 80px 24px;
  color: var(--t2);
}
.cat-empty-icon {
  font-size: 3rem; color: var(--t4); margin-bottom: 12px;
  font-family: 'Syne', sans-serif;
}
.cat-empty h3 {
  font-family: 'Syne', sans-serif; font-size: 1.4rem; color: var(--t1);
  margin-bottom: 6px;
}
.cat-empty p { margin-bottom: 18px; font-size: .9rem; }

/* ── PAGINATION ──────────────────────────────────────────── */
.cat-pagination {
  margin-top: 56px;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.cat-page {
  min-width: 40px; height: 40px; padding: 0 12px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surf); border: 1px solid var(--border);
  border-radius: 10px;
  font: 700 .85rem 'Syne', sans-serif; color: var(--t2);
  cursor: pointer;
  transition: color .2s, background .2s, border-color .2s, transform .15s var(--spring);
}
.cat-page:hover:not([disabled]):not(.active) {
  color: var(--t1); border-color: rgba(167,139,250,.45);
  background: rgba(124,58,237,.08); transform: translateY(-2px);
}
.cat-page.active {
  background: var(--purple); border-color: var(--purple-l); color: #fff;
  box-shadow: 0 6px 20px rgba(124,58,237,.4);
}
.cat-page[disabled] { opacity: .35; cursor: not-allowed; }
.cat-page-ellipsis {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px; height: 40px; color: var(--t4);
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 1000px) {
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .cat-filter-bar { gap: 8px; }
  .cat-fb-spacer { display: none; }
  .cat-sort { flex: 1 1 100%; justify-content: space-between; }
}
@media (max-width: 560px) {
  .cat-grid { grid-template-columns: 1fr; }
  .cat-fb-trigger { flex: 1; justify-content: space-between; }
  .cat-fb-group { flex: 1; }
}
