:root{
  --bg:#0f172a; --card:#0b1227; --muted:#94a3b8; --text:#e5e7eb;
  --brand:#22d3ee; --accent:#a78bfa; --ok:#34d399; --warn:#fbbf24; --danger:#f87171;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif;background:linear-gradient(180deg,#0b1024,var(--bg));color:var(--text)}
a{color:inherit;text-decoration:none}

.container{max-width:1100px;margin-inline:auto;padding:16px}
header{position:sticky;top:0;z-index:20;background:rgba(15,23,42,.7);backdrop-filter:blur(8px);border-bottom:1px solid rgba(148,163,184,.15)}
.bar{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;gap:10px;align-items:center;font-weight:800}
.brand .logo{display:grid;place-items:center;width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--accent));box-shadow:0 8px 24px rgba(34,211,238,.35)}
.nav{display:flex;gap:10px;align-items:center}

.btn,.input,.select{appearance:none;border:1px solid rgba(148,163,184,.25);background:#0b1227;color:var(--text);padding:10px 12px;border-radius:12px}
.btn{cursor:pointer;font-weight:700;text-align:center}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--accent));border:none;color:#091022}

.controls{display:grid;grid-template-columns:1fr 1fr .8fr .8fr .8fr;gap:10px;width:100%}
@media(max-width:900px){.controls{grid-template-columns:1fr 1fr 1fr 1fr 1fr}}
@media(max-width:640px){.controls{grid-template-columns:1fr 1fr 1fr}}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.chip{padding:8px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.25);cursor:pointer;user-select:none}
.chip.active{background:rgba(167,139,250,.15);border-color:var(--accent)}

.section-title{font-weight:800;margin:10px 0 6px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}

.card{background:linear-gradient(180deg,#0d132a,#0b1227);border:1px solid rgba(148,163,184,.15);border-radius:16px;overflow:hidden;box-shadow:0 12px 32px rgba(0,0,0,.35)}

/* ✅ Cover autoajustable: mantiene 16/9 y recorta con object-fit:cover */
.cover{position:relative;width:100%;aspect-ratio:16/9;background:#0a0f22;overflow:hidden}
.cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}

/* Contenido */
.card-body{padding:14px}
.title{display:flex;gap:8px;align-items:center;font-weight:800}
.badge{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.25)}
.muted{color:var(--muted)}
.desc{color:var(--muted);font-size:14px;margin:6px 0 10px}
.meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:12px}

/* ✅ Acciones como chips dentro del recuadro (3 columnas) */
.actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.chipbtn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.25);
  background:#0b1227;color:var(--text);font-weight:700;text-decoration:none;width:100%;
}
.chipbtn.primary{background:linear-gradient(135deg,var(--brand),var(--accent));border:0;color:#091022}
.chipbtn:focus{outline:2px solid rgba(34,211,238,.35);outline-offset:2px}
@media(max-width:520px){.actions{grid-template-columns:1fr}}

.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tag{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.25)}

.hidden{display:none}
.empty{border:1px dashed rgba(148,163,184,.25);border-radius:16px;padding:24px;text-align:center;color:var(--muted);margin-top:12px}

/* Modal Detalles */
dialog{border:none;border-radius:18px;max-width:900px;width:96%;background:#0b1227;color:var(--text);box-shadow:0 20px 60px rgba(0,0,0,.5)}
dialog::backdrop{background:rgba(2,6,23,.7)}
.modal-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(148,163,184,.15);padding:12px 16px}
.modal-body{display:grid;gap:12px;padding:12px 16px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.gallery img{width:100%;aspect-ratio:1.4/1;border-radius:12px;object-fit:cover}
.modal-actions{display:flex;gap:8px;flex-wrap:wrap}
@media(max-width:520px){.gallery{grid-template-columns:repeat(2,1fr)}}
