:root {
  --fondo: #0d0c12;
  --panel: #16141d;
  --borde: #2a2733;
  --texto: #e6e2ef;
  --tenue: #9a93ad;
  --acento: #7c5cff;
  --discord: #5865f2;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 1.5rem 1rem 3rem;
  background: radial-gradient(circle at 50% 0%, #1a1726, var(--fondo) 70%);
  color: var(--texto);
  font-family: system-ui, "Segoe UI", Roboto, sans-serif;
}

.panel {
  background: var(--panel);
  border: 1px solid var(--borde);
  border-radius: 14px;
  padding: 2.5rem 2.75rem;
  max-width: 30rem;
  text-align: center;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5);
}

.marca {
  margin: 0 0 1.25rem;
  font-size: 1.9rem;
  letter-spacing: 0.04em;
}

.saludo { font-size: 1.1rem; margin: 0.5rem 0; }
.rol { color: var(--tenue); margin: 0.25rem 0 1.5rem; }

.etiqueta {
  display: inline-block;
  padding: 0.15rem 0.6rem;
  border-radius: 999px;
  background: rgba(124, 92, 255, 0.18);
  color: var(--acento);
  font-weight: 600;
}

.error { color: #ff8a8a; margin: 0.5rem 0 1.5rem; }

.boton {
  display: inline-block;
  margin: 0.35rem 0.25rem 0;
  padding: 0.65rem 1.3rem;
  border-radius: 9px;
  background: var(--borde);
  color: var(--texto);
  text-decoration: none;
  font-weight: 600;
  transition: filter 0.15s ease;
}

.boton:hover { filter: brightness(1.25); }
.boton--discord { background: var(--discord); color: #fff; }

.pie {
  margin-top: 2rem;
  color: var(--tenue);
  font-size: 0.78rem;
  letter-spacing: 0.03em;
}

/* --- F1: panel de gestión (listado + detalle) --- */

.panel--login { margin-top: 8vh; }
.panel--lista,
.panel--detalle {
  max-width: 52rem;
  text-align: left;
}

.cabecera {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.cabecera:has(.nav) { justify-content: space-between; }

.marca {
  font-size: 1.5rem;
  color: var(--texto);
  text-decoration: none;
  letter-spacing: 0.04em;
}

.nav {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  font-size: 0.9rem;
}
.nav a { color: var(--acento); text-decoration: none; }
.nav a:hover { text-decoration: underline; }
.nav-yo { color: var(--tenue); }

.tenue-text { color: var(--tenue); }

.lista-cabecera {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.lista-cabecera h2 { margin: 0; }

.tarjetas {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.tarjeta {
  border: 1px solid var(--borde);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
  transition: border-color 0.15s ease, background 0.15s ease;
}
.tarjeta:hover {
  border-color: var(--acento);
  background: rgba(124, 92, 255, 0.06);
}
.tarjeta-link {
  display: block;
  padding: 0.85rem 1rem;
  color: var(--texto);
  text-decoration: none;
}
.tarjeta-cab {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}
.tarjeta-titulo { font-weight: 600; font-size: 1.05rem; }
.tarjeta-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  color: var(--tenue);
  font-size: 0.88rem;
}
.tarjeta-autor { margin-top: 0.3rem; color: var(--tenue); font-size: 0.82rem; }

.chip {
  font-size: 0.72rem;
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  font-weight: 600;
}
.chip--oculta { background: rgba(154, 147, 173, 0.18); color: var(--tenue); }
.chip--sorteo { background: rgba(124, 92, 255, 0.18); color: var(--acento); }

.volver { margin: 0 0 1rem; }
.volver a { color: var(--acento); text-decoration: none; }
.detalle-titulo { margin: 0 0 0.5rem; }

.ficha {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 0.6rem 1.2rem;
  margin: 1rem 0;
}
.ficha dt { color: var(--tenue); font-size: 0.8rem; margin: 0; }
.ficha dd { margin: 0.1rem 0 0; font-weight: 600; }

.bloque { margin: 1.25rem 0; }
.bloque h3 { margin: 0 0 0.4rem; font-size: 1rem; }
.sinopsis { white-space: pre-wrap; line-height: 1.5; margin: 0; }

.grupo { margin: 0.4rem 0; }
.grupo-titulo { font-weight: 600; margin-right: 0.4rem; }
.grupo-nombres { color: var(--tenue); }

.cartel { max-width: 100%; border-radius: 10px; margin: 1rem 0; }
