:root {
  /* 🎨 PALETA ORIGINAL (ZELDA) */
  --color-primario: hsl(45, 80%, 55%);      /* dorado */
  --color-secundario: hsl(150, 20%, 18%);   /* botones */
  --color-fondo: hsl(150, 20%, 8%);         /* fondo oscuro */
  --color-panel: hsl(150, 15%, 12%);        /* tarjetas */
  --color-borde: hsl(150, 15%, 20%);

  --color-texto: hsl(45, 30%, 90%);
  --color-texto-secundario: hsl(150, 10%, 55%);

  --color-hover: hsl(120, 30%, 25%);
  --color-oscuro: hsl(150, 20%, 8%);
}

/* =========================
        RESET
========================= */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  text-decoration: none
}

body {
  background-color: var(--color-fondo);
  color: var(--color-texto);
  font-family: 'Lora', serif;

  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* =========================
        MAIN
========================= */

.pagina {
  max-width: 700px;
  width: 100%;
  margin: 0 auto;
  padding: 60px 20px 40px;

  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* =========================
        CABECERA
========================= */

.cabecera {
  text-align: center;
  margin-bottom: 40px;
}

.titulo {
  font-size: 3.5rem;
  font-weight: 700;
  color: var(--color-primario);
  letter-spacing: 0.08em;
  text-shadow: 0 0 20px hsla(45, 80%, 55%, 0.3);
  margin-bottom: 8px;
}

.subtitulo {
  font-size: 1.1rem;
  color: var(--color-texto-secundario);
}

/* =========================
        TIPOS
========================= */

.tipos ul {
  display: flex;
  gap: 8px;
  list-style: none;
  justify-content: center;
  margin-bottom: 25px;
}

.tipo {
  font-family: 'Cinzel', serif;
  font-size: 0.85rem;
  padding: 10px 20px;
  border: none;
  border-radius: 8px;
  cursor: pointer;

  background: var(--color-secundario);
  color: var(--color-texto);
  transition: 0.2s;
}

.tipo:hover {
  background: var(--color-hover);
}

.tipo.activo {
  background: var(--color-primario);
  color: var(--color-oscuro);
}

/* =========================
        BUSCADOR
========================= */

.formulario-busqueda {
  width: 100%;
  display: flex;
  gap: 8px;
  margin-bottom: 40px;
}

.entrada-busqueda {
  flex: 1;
  height: 48px;
  padding: 0 16px;
  font-size: 1rem;
  border-radius: 8px;
  border: 1px solid var(--color-borde);
  background: var(--color-panel);
  color: var(--color-texto);
}

.entrada-busqueda::placeholder {
  color: var(--color-texto-secundario);
}


.oculto {
  position: absolute;
  left: -9999px;
}

.resultados {
  width: 100%;
}

/* =========================
        PIE
========================= */

.pie {
  text-align: center;
  padding: 20px;
  border-top: 1px solid var(--color-borde);
  color: var(--color-texto-secundario);
  font-size: 0.85rem;
    margin-top: auto;
}

/* =========================
        JUEGOS
========================= */

#contenedor-juegos {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 15px;
  margin-top: 20px;
}

.tarjeta {
  background: var(--color-panel);
  border: 1px solid var(--color-borde);
  border-radius: 12px;
  padding: 15px;

  transition: 0.2s;
  box-shadow: 0 0 10px rgba(0,0,0,0.3);
}

.tarjeta:hover {
  transform: translateY(-4px);
  border-color: var(--color-primario);
  box-shadow: 0 0 20px hsla(45, 80%, 55%, 0.15);
}

.tarjeta h2 {
  font-size: 1.1rem;
  color: var(--color-primario);
  margin-bottom: 10px;
}

.tarjeta p {
  font-size: 0.9rem;
  margin: 4px 0;
  color: var(--color-texto);
}

.tarjeta strong {
  color: var(--color-texto-secundario);
}

@media (max-width: 600px) {
  #contenedor-juegos {
    grid-template-columns: 1fr;
  }
}

/* =========================
        TIPO
========================= */

.historial {
    max-width: 600px;
    margin: 30px auto;
    padding: 0 15px;
    text-align: center;
    color: var(--color-texto);
}


.historial-titulo {
    margin-bottom: 15px;
    font-size: 20px;
    color: var(--color-texto);
}


.historial-lista {
    list-style: none;
    padding: 0;
    margin: 0;
}

.historial-item {
    background: linear-gradient(
        145deg,
        var(--color-panel),
        var(--color-secundario)
    );

    border: 1px solid var(--color-borde);
    border-left: 4px solid var(--color-primario);

    color: var(--color-texto);

    margin-bottom: 10px;
    padding: 12px 14px;

    border-radius: 12px;

    display: flex;
    justify-content: space-between;
    align-items: center;

    gap: 12px;

    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.historial-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.4);
}

.historial-info h3 {
    margin: 0;
    font-size: 14px;
    color: var(--color-texto);
}

.historial-info p {
    margin: 2px 0 0;
    font-size: 12px;
    color: var(--color-texto-secundario);
}

.historial-info small {
    font-size: 11px;
    color: var(--color-texto-secundario);
    opacity: 0.8;
}

.btn-delete {
    background-color: hsl(0, 70%, 50%);
    color: white;
    border: none;

    padding: 5px 8px;
    border-radius: 6px;

    cursor: pointer;
    font-size: 12px;

    transition: 0.2s;
}

.btn-delete:hover {
    background-color: hsl(0, 70%, 40%);
    transform: scale(1.05);
}

.btn-limpiar {
    margin-top: 15px;
    padding: 8px 12px;

    border: 1px solid var(--color-borde);
    border-radius: 8px;

    background: var(--color-secundario);
    color: var(--color-texto);

    cursor: pointer;

    transition: 0.2s;
}

.btn-limpiar:hover {
    background: var(--color-hover);
}

.historial-vacio {
    color: var(--color-texto-secundario);
    font-size: 14px;
    margin-top: 10px;
}

.panel-favoritos {
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px;
    background-color: var(--color-fondo);
    color: var(--color-texto);
}

/* ==========================
   TÍTULO
========================== */
.titulo-panel {
    font-size: 28px;
    text-align: center;
    color: var(--color-primario);
}

/* ==========================
   BOTONES
========================== */
.acciones-favoritos {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    list-style: none;
    justify-content: center;
    padding: 0;
}

.boton {
    padding: 10px 14px;
    border: 1px solid var(--color-borde);
    border-radius: 8px;
    background-color: var(--color-secundario);
    color: var(--color-texto);
    cursor: pointer;
    transition: 0.2s ease;
    font-size: 14px;
}

.boton:hover {
    background-color: var(--color-hover);
    transform: translateY(-2px);
}

.boton-peligro {
    background-color: hsl(0, 60%, 30%);
    border: 1px solid hsl(0, 60%, 40%);
}

.boton-peligro:hover {
    background-color: hsl(0, 60%, 40%);
}

/* ==========================
   LISTA
========================== */
.lista-favoritos {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 15px;
    padding: 10px;
}

/* ==========================
   TARJETAS
========================== */
.tarjeta-favorito {
    background-color: var(--color-panel);
    border: 1px solid var(--color-borde);
    border-radius: 12px;
    padding: 15px;
    transition: 0.2s ease;
}

.tarjeta-favorito:hover {
    transform: translateY(-5px);
    border-color: var(--color-primario);
    box-shadow: 0 0 10px rgba(255, 200, 0, 0.1);
}

.tarjeta-favorito h3 {
    margin: 0 0 10px 0;
    font-size: 18px;
    color: var(--color-primario);
}

.tarjeta-favorito p {
    font-size: 14px;
    color: var(--color-texto-secundario);
    margin-bottom: 8px;
}

.tarjeta-favorito small {
    color: var(--color-texto-secundario);
    font-size: 12px;
}

/* ==========================
   MENSAJE VACÍO
========================== */
.mensaje-vacio {
    text-align: center;
    font-size: 16px;
    color: var(--color-texto-secundario);
    padding: 20px;
}