/* ===== Hero mejorado ===== */
.cat-hero{
  position: relative; color:#fff; isolation:isolate;
  --panel-bg: rgba(18,19,22,.42);
  --panel-bd: rgba(255,255,255,.14);
  --shadow: 0 18px 46px rgba(0,0,0,.30);
}
.cat-hero__bg{
  position:absolute; inset:0; background-size:cover; background-position:center;
  filter: saturate(.95) brightness(.92);
}
.cat-hero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.35; }
.cat-hero__overlay{
  position:absolute; inset:0;
  background: color-mix(in oklab, var(--ov-color) calc(var(--ov-op, .48) * 100%), transparent);
}
.cat-hero__vignette{ position:absolute; inset:0; background: radial-gradient(120% 90% at 50% 120%, transparent 0%, rgba(0,0,0,.55) 70%); }
.cat-hero__glow{ position:absolute; inset:auto 0 0 0; height: 42%;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.50));
}
.cat-hero__pattern{
  position:absolute; inset:0;
  opacity:.06;
  background:
    radial-gradient(1px 1px at 20px 20px, #fff 1px, transparent 1px),
    radial-gradient(1px 1px at 60px 60px, #fff 1px, transparent 1px);
  background-size: 80px 80px;
  mix-blend-mode: screen;
}

.cat-hero__grid{
  position:relative; z-index:2;
  display:grid; grid-template-columns: 1.2fr .8fr; gap:32px; align-items:center;
  min-height: 46vh; padding: clamp(36px,5vw,72px) 0;
}
.cat-hero__panel{
  backdrop-filter: blur(6px);
  background: var(--panel-bg);
  border:1px solid var(--panel-bd);
  border-radius: 18px;
  padding: clamp(16px,3vw,26px);
  box-shadow: var(--shadow);
  max-width: 840px;
}
.cat-hero__title{ font-size: clamp(32px,5.6vw,64px); font-weight:900; margin:0 0 8px; letter-spacing:.02em; }
.cat-hero__subtitle{ font-size: clamp(15px,2.2vw,20px); color: rgba(255,255,255,.92); margin: 0 0 16px; }

.cat-hero__chips{ display:flex; gap:10px; flex-wrap:wrap; margin: 4px 0 14px; }
.chip{
  display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px;
  background: rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); font-size:13px;
}

.cat-hero__ctas{ display:flex; gap:12px; margin: 6px 0 10px; }
.btn-accent{
  display:inline-flex; align-items:center; gap:8px;
  padding: 10px 18px; border-radius: 12px; font-weight:700; text-decoration:none;
  background: var(--accent); color:#fff; border:1px solid color-mix(in oklab, var(--accent) 70%, #000);
  box-shadow: 0 10px 22px color-mix(in oklab, var(--accent) 26%, transparent);
  transition: transform .15s ease, filter .15s ease;
}
.btn-accent:hover{ transform: translateY(-1px); filter: brightness(1.03); }

.badge-soft{
  background: rgba(255,255,255,.10); border:1px dashed rgba(255,255,255,.22);
  padding:6px 10px; border-radius:10px; font-size:12px; margin-right:6px;
}
.cat-hero__badges{ margin-top:6px; }

.cat-hero__side{
  display:flex; justify-content:flex-end; align-items:center;
}
.cat-hero__side img{
  max-height: 240px; width:auto; filter: drop-shadow(0 14px 30px rgba(0,0,0,.35));
  opacity:.95;
}

/* Highlights */
.cat-hero__features{
  position: relative; z-index:2; margin-top: -8px;
  background: linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.28));
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.feat-list{
  list-style:none; display:grid; grid-template-columns: repeat(3,minmax(0,1fr));
  gap:18px; margin:0; padding: 12px 0;
}
.feat{ display:flex; gap:12px; align-items:flex-start; color:#fff; }
.feat i{ font-size:20px; color: var(--accent); margin-top:2px; }
.feat-label{ font-weight:700; }
.feat-desc{ color: rgba(255,255,255,.85); }

/* Tema claro (por si alguna categoría lo requiere) */
.cat-hero--light{ color:#111; }
.cat-hero--light .cat-hero__overlay{ background: color-mix(in oklab, #fff 35%, transparent); }
.cat-hero--light .cat-hero__panel{ --panel-bg: rgba(255,255,255,.68); --panel-bd: rgba(0,0,0,.06); }
.cat-hero--light .chip{ background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.10); color:#111; }
.cat-hero--light .badge-soft{ background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.10); color:#111; }
.cat-hero--light .feat{ color:#222; }
.cat-hero--light .cat-hero__features{ background: linear-gradient(180deg, rgba(255,255,255,.80), rgba(255,255,255,.92)); }

/* Responsive */
@media (max-width: 992px){
  .cat-hero__grid{ grid-template-columns:1fr; gap:16px; min-height: 44vh; }
  .cat-hero__side{ justify-content:flex-start; }
  .cat-hero__side img{ max-height: 180px; }
  .feat-list{ grid-template-columns: 1fr; }
}
