/* Ultimate Pack — dashboard. Tema dark + gold (tokens del proyecto). */
:root{
  --gold:#F5A623; --gold-d:#C8841A;
  --dark:#0C0C0C; --d2:#141414; --d3:#1C1C1C;
  --border:#252525; --text:#E8E8E8; --muted:#8A8A8A;
  --green:#22C55E; --red:#EF4444;
  --r:16px; --r-sm:10px;
  --maxw:1180px;
  font-synthesis:none;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--dark); color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,sans-serif;
  -webkit-font-smoothing:antialiased; line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer}

/* ---------- Auth (login / claim) ---------- */
.auth-wrap{min-height:100dvh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(900px 500px at 50% -10%, rgba(245,166,35,.08), transparent 60%), var(--dark);}
.auth-card{width:100%;max-width:400px;background:var(--d2);border:1px solid var(--border);
  border-radius:var(--r);padding:32px 28px;box-shadow:0 24px 60px rgba(0,0,0,.5)}
.auth-logo{height:56px;margin:0 auto 18px;display:block}
.auth-card h1{font-size:21px;font-weight:700;text-align:center;letter-spacing:-.01em}
.auth-card .sub{color:var(--muted);font-size:14px;text-align:center;margin:6px 0 22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.field input{width:100%;background:var(--d3);border:1px solid var(--border);color:var(--text);
  border-radius:var(--r-sm);padding:12px 14px;font-size:15px;outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(245,166,35,.15)}
.btn{width:100%;border:none;border-radius:var(--r-sm);padding:13px 16px;font-weight:700;font-size:15px;
  background:linear-gradient(180deg,var(--gold),var(--gold-d));color:#1a1206;transition:filter .15s,transform .05s}
.btn:hover{filter:brightness(1.05)}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.6;cursor:not-allowed}
.auth-foot{text-align:center;margin-top:18px;font-size:13.5px;color:var(--muted)}
.auth-foot a{color:var(--gold);font-weight:600}
.msg{font-size:13.5px;border-radius:var(--r-sm);padding:10px 12px;margin-bottom:14px;display:none}
.msg.err{display:block;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#fca5a5}
.msg.ok{display:block;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);color:#86efac}

/* ---------- Dashboard ---------- */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;
  padding:14px 22px;background:rgba(12,12,12,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.topbar .logo{height:34px}
.topbar .brand{font-weight:700;letter-spacing:-.01em}
.topbar .brand small{display:block;color:var(--muted);font-weight:500;font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.topbar .spacer{flex:1}
.logout{background:var(--d3);border:1px solid var(--border);color:var(--text);border-radius:999px;padding:8px 16px;font-size:13px;font-weight:600}
.logout:hover{border-color:var(--gold);color:var(--gold)}

.container{max-width:var(--maxw);margin:0 auto;padding:26px 22px 80px}
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;color:var(--muted);font-size:14px;margin-bottom:20px}
.crumbs a{cursor:pointer}
.crumbs a:hover{color:var(--gold)}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--text);font-weight:600}

.section-title{font-size:22px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px}
.section-sub{color:var(--muted);font-size:14px;margin-bottom:22px}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.card{position:relative;background:var(--d2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;
  cursor:pointer;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);border-color:rgba(245,166,35,.55);box-shadow:0 16px 36px rgba(0,0,0,.45)}
.card .cover{aspect-ratio:1.9/1;width:100%;object-fit:cover;background:var(--d3);display:block}
.card .cover.ph{display:grid;place-items:center;color:var(--text);font-size:19px;font-weight:700;text-align:center;
  padding:18px;background:linear-gradient(135deg,var(--d3),#231a08);letter-spacing:-.01em}
/* tag de acción flotante sobre el banner */
.card .tag{position:absolute;top:10px;right:10px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:#1a1206;background:var(--gold);padding:3px 9px;border-radius:999px;opacity:0;transform:translateY(-4px);transition:opacity .14s,transform .14s}
.card:hover .tag{opacity:1;transform:translateY(0)}
.card .cap{padding:11px 13px;border-top:1px solid var(--border)}
.card .cap h3{font-size:14px;font-weight:600;letter-spacing:-.01em}
.card .cap p{font-size:12px;color:var(--muted);margin-top:2px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- Modal ---------- */
.modal-back{position:fixed;inset:0;z-index:50;display:none;place-items:center;padding:20px;
  background:rgba(0,0,0,.72);backdrop-filter:blur(4px)}
.modal-back.open{display:grid}
.modal{width:100%;max-width:560px;max-height:88dvh;overflow-y:auto;background:var(--d2);
  border:1px solid var(--border);border-radius:var(--r);padding:0 0 26px;box-shadow:0 30px 70px rgba(0,0,0,.6);position:relative}
.modal-cover{width:100%;aspect-ratio:1.9/1;object-fit:cover;border-radius:var(--r) var(--r) 0 0;display:block}
.modal h3{font-size:22px;font-weight:700;letter-spacing:-.015em;padding:22px 30px 0;line-height:1.2}
.modal-desc{padding:14px 30px 4px;max-width:62ch}
.modal-desc .lead{font-size:16.5px;line-height:1.6;color:var(--text);font-weight:500;margin-bottom:15px}
.modal-desc p{font-size:14.5px;line-height:1.72;color:#C7C7C7;margin-bottom:12px}
.modal-desc p:last-child{margin-bottom:0}
.modal-foot{padding:20px 30px 0;margin-top:18px;border-top:1px solid var(--border)}
.modal .btn{width:100%;display:block;text-align:center}
.modal-x{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:999px;border:none;
  background:rgba(0,0,0,.55);color:#fff;font-size:22px;line-height:1;display:grid;place-items:center;backdrop-filter:blur(4px)}
.modal-x:hover{background:rgba(0,0,0,.8)}

.empty{color:var(--muted);text-align:center;padding:60px 20px}
.loading{color:var(--muted);text-align:center;padding:80px 20px}

@media(max-width:560px){
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:13px}
  .container{padding:20px 16px 70px}
}
