.categorias-view,
.lista-view,
.estado-vazio {
  display: grid;
  gap: var(--espaco-lg);
  height: 100%;
}

.cabecalho-view {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--espaco-lg);
}

.cabecalho-view h1,
.cabecalho-view h2 {
  margin: 0;
  color: var(--cor-titulo);
  font-family: var(--fonte-titulo);
  font-size: clamp(var(--texto-xl), 3vw, var(--texto-3xl));
}

.cabecalho-view p {
  max-width: 620px;
  margin: var(--espaco-sm) 0 0;
}

.categorias-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--espaco-lg);
}

.categoria-card {
  display: grid;
  gap: var(--espaco-md);
  padding: var(--espaco-lg);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-lg);
  color: var(--cor-texto);
  background:
    linear-gradient(135deg, var(--cor-luz-24), transparent),
    linear-gradient(120deg, var(--cor-papel), var(--cor-papel-escuro));
  box-shadow: 0 16px 30px var(--cor-sombra);
}

.categoria-card:hover,
.categoria-card:focus-visible {
  transform: translateY(-2px);
}

.categoria-card-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--espaco-md);
}

.categoria-icone {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 1px solid var(--cor-borda);
  font-size: var(--texto-xl);
  background-color: var(--cor-luz-18);
}

.categoria-card h3 {
  margin: 0;
  color: var(--cor-titulo);
  font-family: var(--fonte-titulo);
  font-size: var(--texto-xl);
}

.categoria-card small {
  color: var(--cor-acento);
  font-family: var(--fonte-ui);
}

.categoria-card-acoes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--espaco-sm);
  margin-top: var(--espaco-sm);
}

.categoria-card-acoes .botao-primario,
.categoria-card-acoes .botao-secundario {
  flex: 1 1 auto;
  text-align: center;
}

.favoritos-destaque {
  display: grid;
  gap: var(--espaco-md);
  padding: var(--espaco-lg);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-lg);
  background:
    linear-gradient(180deg, var(--cor-luz-20), transparent 46%),
    linear-gradient(120deg, var(--cor-papel), var(--cor-papel-escuro));
  box-shadow: 0 16px 30px var(--cor-sombra);
}

.favoritas-lista {
  grid-template-columns: 1fr;
}

.lista-scroll {
  overflow: auto;
  padding-right: var(--espaco-sm);
}

.receitas-lista {
  display: grid;
  gap: var(--espaco-md);
}

.item-lista {
  display: grid;
  grid-template-columns: 112px 1fr auto;
  gap: var(--espaco-md);
  align-items: center;
  padding: var(--espaco-md);
  border: 1px solid var(--cor-borda);
  border-radius: var(--raio-lg);
  color: var(--cor-texto);
  background-color: var(--cor-papel);
}

.item-lista:hover,
.item-lista:focus-visible {
  transform: translateY(-2px);
}

.thumb-receita {
  position: relative;
  width: 112px;
  height: 112px;
  border-radius: var(--raio-md);
  overflow: hidden;
  border: 1px solid var(--cor-borda);
  background-color: var(--cor-papel-escuro);
}

.thumb-receita img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

:root[data-theme="dark"] .thumb-receita::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(9, 6, 4, 0.04), rgba(9, 6, 4, 0.26));
}

:root[data-theme="dark"] .thumb-receita img {
  filter: brightness(0.92) saturate(0.92);
}

.item-lista h3 {
  margin: 0 0 var(--espaco-xs);
  color: var(--cor-titulo);
  font-family: var(--fonte-titulo);
}

.meta-receita {
  display: flex;
  flex-wrap: wrap;
  gap: var(--espaco-sm);
  margin-top: var(--espaco-sm);
  font-family: var(--fonte-ui);
  font-size: var(--texto-sm);
}

.meta-chip {
  padding: var(--espaco-xs) var(--espaco-sm);
  border-radius: 999px;
  border: 1px solid var(--cor-borda);
  background-color: var(--cor-luz-18);
}

.meta-chip--favorite {
  color: var(--cor-acento);
  background:
    linear-gradient(135deg, var(--cor-luz-20), transparent),
    var(--cor-papel);
}

.navegacao-livro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--espaco-md);
}

.estado-vazio {
  align-content: center;
  min-height: 100%;
  padding: var(--espaco-2xl);
  border: 1px dashed var(--cor-borda);
  border-radius: var(--raio-lg);
  text-align: center;
  background-color: var(--cor-luz-14);
}

.estado-vazio h2 {
  margin: 0;
  color: var(--cor-titulo);
  font-family: var(--fonte-titulo);
}

@media (max-width: 768px) {
  .categorias-grid {
    grid-template-columns: 1fr;
  }

  .item-lista {
    grid-template-columns: 1fr;
  }

  .thumb-receita {
    width: 100%;
    height: 220px;
  }

  .navegacao-livro,
  .cabecalho-view {
    flex-direction: column;
    align-items: stretch;
  }
}
