/* ============================================================
   components.css — header, footer, cards, botões, formulários,
   badges, alertas, toast. Depende de tokens.css + base.css.
   ============================================================ */

/* ---------- Header ---------- */
.header { background: var(--cor-marca); color: var(--cor-marca-texto); }
.header-top {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: var(--esp-3); padding: var(--esp-2) var(--esp-4);
  max-width: var(--largura-max); margin: 0 auto;
}
.logo { font-weight: 700; font-size: 1.25rem; color: var(--cor-marca-texto); white-space: nowrap; }
.logo:hover { text-decoration: none; }
.busca-form { flex: 1 1 100%; display: flex; order: 3; }
.busca-form input {
  flex: 1; border: none; border-radius: var(--raio) 0 0 var(--raio);
  padding: var(--esp-2) var(--esp-3); font-size: var(--texto-md);
  box-shadow: var(--sombra-card); min-width: 0;
}
.busca-form button {
  border: none; background: var(--cor-superficie); color: var(--cor-texto-suave);
  border-radius: 0 var(--raio) var(--raio) 0; padding: 0 var(--esp-4);
  border-left: 1px solid var(--cor-borda); box-shadow: var(--sombra-card);
}
.header-links { display: flex; align-items: center; gap: var(--esp-4); margin-left: auto; font-size: var(--texto-sm); }
.header-links a { color: var(--cor-marca-texto); }
.nav-categorias { background: var(--cor-marca); border-top: 1px solid rgba(0,0,0,.07); }
.nav-categorias ul {
  display: flex; gap: var(--esp-4); list-style: none; overflow-x: auto;
  max-width: var(--largura-max); margin: 0 auto; padding: var(--esp-2) var(--esp-4);
  font-size: var(--texto-sm); white-space: nowrap;
}
.nav-categorias a { color: var(--cor-marca-texto); }
.badge-carrinho {
  background: var(--cor-erro); color: #fff; border-radius: 999px;
  font-size: var(--texto-xs); padding: 0 6px; margin-left: 2px;
}
@media (min-width: 768px) {
  .busca-form { flex: 1; order: 0; max-width: 600px; }
}

/* ---------- Footer ---------- */
.footer {
  background: var(--cor-superficie); border-top: 1px solid var(--cor-borda);
  margin-top: var(--esp-8); padding: var(--esp-6) var(--esp-4);
  font-size: var(--texto-sm); color: var(--cor-texto-suave);
}
.footer-inner { max-width: var(--largura-max); margin: 0 auto; display: flex; flex-wrap: wrap; gap: var(--esp-6); justify-content: space-between; }

/* ---------- Botões ---------- */
.btn {
  display: inline-block; border: none; border-radius: var(--raio);
  padding: var(--esp-3) var(--esp-6); font-size: var(--texto-md);
  text-align: center; text-decoration: none;
}
.btn:hover { text-decoration: none; }
.btn:disabled { opacity: .6; cursor: not-allowed; }
.btn-primario { background: var(--cor-acao); color: #fff; }
.btn-primario:hover { background: var(--cor-acao-hover); }
.btn-secundario { background: var(--cor-acao-suave); color: var(--cor-acao); }
.btn-perigo { background: var(--cor-erro); color: #fff; }
.btn-fantasma { background: transparent; color: var(--cor-acao); }
.btn-bloco { display: block; width: 100%; }
.btn-sm { padding: var(--esp-1) var(--esp-3); font-size: var(--texto-sm); }

/* ---------- Painéis / cards ---------- */
.painel {
  background: var(--cor-superficie); border-radius: var(--raio);
  box-shadow: var(--sombra-card); padding: var(--esp-4); margin-bottom: var(--esp-4);
}

.grid-produtos {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--esp-3); margin-bottom: var(--esp-6);
}
.card-produto {
  background: var(--cor-superficie); border-radius: var(--raio);
  box-shadow: var(--sombra-card); overflow: hidden; display: block; color: inherit;
}
.card-produto:hover { box-shadow: var(--sombra-card-hover); text-decoration: none; }
.card-produto .img {
  aspect-ratio: 1; background: #f5f5f5; display: flex; align-items: center;
  justify-content: center; color: var(--cor-texto-sutil); font-size: 2rem;
  border-bottom: 1px solid var(--cor-borda); width: 100%; object-fit: cover;
}
.card-produto .corpo { padding: var(--esp-3); }
.card-produto .titulo {
  font-size: var(--texto-sm); color: var(--cor-texto-suave);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; min-height: 2.4em;
}
.card-produto .preco { font-size: var(--texto-lg); font-weight: 400; margin: var(--esp-1) 0; }
.card-produto .extra { font-size: var(--texto-xs); color: var(--cor-positivo); }
.card-produto .cidade { font-size: var(--texto-xs); color: var(--cor-texto-sutil); margin-top: var(--esp-1); }

/* ---------- Badges / chips ---------- */
.badge { display: inline-block; font-size: var(--texto-xs); border-radius: 999px; padding: 2px 10px; font-weight: 600; }
.badge-positivo { background: #E6F7EE; color: var(--cor-positivo); }
.badge-alerta   { background: #FEF3E0; color: var(--cor-alerta); }
.badge-erro     { background: #FDE8EA; color: var(--cor-erro); }
.badge-info     { background: var(--cor-acao-suave); color: var(--cor-acao); }
.badge-neutro   { background: var(--cor-fundo); color: var(--cor-texto-suave); }

/* ---------- Formulários ---------- */
.campo { margin-bottom: var(--esp-4); }
.campo label { display: block; font-size: var(--texto-sm); font-weight: 600; margin-bottom: var(--esp-1); }
.campo input, .campo select, .campo textarea {
  width: 100%; border: 1px solid var(--cor-borda); border-radius: var(--raio);
  padding: var(--esp-2) var(--esp-3); font-size: var(--texto-md); font-family: inherit;
  background: var(--cor-superficie);
}
.campo .ajuda { font-size: var(--texto-xs); color: var(--cor-texto-sutil); margin-top: var(--esp-1); }
.campo .erro-msg { font-size: var(--texto-xs); color: var(--cor-erro); margin-top: var(--esp-1); }

/* ---------- Tabelas ---------- */
.tabela { width: 100%; border-collapse: collapse; font-size: var(--texto-sm); }
.tabela th, .tabela td {
  text-align: left; padding: var(--esp-3); border-bottom: 1px solid var(--cor-borda);
  vertical-align: middle;
}
.tabela th { color: var(--cor-texto-suave); font-weight: 600; }
.tabela-scroll { overflow-x: auto; }

/* ---------- Linha de campos (grid de formulário) ---------- */
.linha-campos { display: grid; gap: var(--esp-3); }
@media (min-width: 768px) {
  .linha-campos { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); }
}

/* ---------- Miniaturas (gerenciador de imagens) ---------- */
.grid-thumbs { display: flex; flex-wrap: wrap; gap: var(--esp-3); }
.thumb {
  width: 120px; border: 1px solid var(--cor-borda); border-radius: var(--raio);
  overflow: hidden; background: var(--cor-superficie);
}
.thumb img { width: 120px; height: 120px; object-fit: cover; display: block; }
.thumb .acoes { display: flex; justify-content: space-between; padding: var(--esp-1); gap: var(--esp-1); }
.thumb .acoes button {
  border: none; background: transparent; color: var(--cor-acao);
  font-size: var(--texto-sm); padding: 2px 4px; border-radius: var(--raio);
}
.thumb .capa { font-size: var(--texto-xs); color: var(--cor-positivo); text-align: center; padding: 2px; }

/* ---------- Favoritos (coração) ---------- */
.btn-favorito {
  border: 1px solid var(--cor-borda); background: var(--cor-superficie);
  color: var(--cor-texto-suave); border-radius: 999px; cursor: pointer;
  width: 36px; height: 36px; font-size: 1.1rem; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
}
.btn-favorito:hover { border-color: var(--cor-erro); color: var(--cor-erro); }
.btn-favorito.ativo { color: var(--cor-erro); border-color: var(--cor-erro); }
.btn-favorito:disabled { opacity: .5; cursor: default; }
.card-produto { position: relative; }
.card-fav {
  position: absolute; top: var(--esp-2); right: var(--esp-2); z-index: 1;
  width: 32px; height: 32px; font-size: 1rem; box-shadow: var(--sombra-card);
}

/* ---------- Página de produto ---------- */
.layout-produto { display: grid; gap: var(--esp-4); }
.galeria .principal {
  background: var(--cor-superficie); border: 1px solid var(--cor-borda);
  border-radius: var(--raio); aspect-ratio: 1 / 1; width: 100%;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  font-size: 4rem;
}
.galeria .principal img { width: 100%; height: 100%; object-fit: contain; }
.galeria .thumbs { display: flex; gap: var(--esp-2); margin-top: var(--esp-2); flex-wrap: wrap; }
.galeria .thumbs button {
  width: 56px; height: 56px; padding: 0; border: 1px solid var(--cor-borda);
  border-radius: var(--raio); background: var(--cor-superficie); cursor: pointer; overflow: hidden;
}
.galeria .thumbs button.ativo { border-color: var(--cor-acao); }
.galeria .thumbs img { width: 100%; height: 100%; object-fit: cover; display: block; }

.preco-grande { font-size: var(--texto-xl); font-weight: 400; margin: var(--esp-3) 0; }
.estrelas { color: var(--cor-alerta); letter-spacing: 1px; }

.variacao-eixo { margin-top: var(--esp-3); }
.variacao-eixo .opcoes { display: flex; flex-wrap: wrap; gap: var(--esp-2); margin-top: var(--esp-1); }
.sel {
  border: 1px solid var(--cor-borda); background: var(--cor-superficie); color: var(--cor-texto);
  border-radius: var(--raio); padding: var(--esp-2) var(--esp-3); font-size: var(--texto-sm); cursor: pointer;
}
.sel:hover { border-color: var(--cor-acao); }
.sel.ativo { border-color: var(--cor-acao); background: var(--cor-acao-suave); color: var(--cor-acao); }
.sel:disabled { opacity: .45; cursor: not-allowed; text-decoration: line-through; }

@media (min-width: 768px) {
  .layout-produto .topo { display: grid; grid-template-columns: 1fr 1fr; gap: var(--esp-6); align-items: start; }
}

/* ---------- Busca (filtros + resultados) ---------- */
.layout-busca { display: grid; gap: var(--esp-4); }
.filtros .secao { font-weight: 600; font-size: var(--texto-sm); margin: var(--esp-3) 0 var(--esp-1); }
.filtros .faixa-preco { display: flex; align-items: center; gap: var(--esp-2); }
.filtros .faixa-preco input { width: 100%; }
@media (min-width: 768px) {
  .layout-busca { grid-template-columns: 240px 1fr; align-items: start; }
}

/* ---------- Carrinho ---------- */
.layout-carrinho { display: grid; gap: var(--esp-4); }
.carrinho-item {
  display: grid; grid-template-columns: 64px 1fr auto; gap: var(--esp-3);
  align-items: center; padding: var(--esp-3) 0; border-bottom: 1px solid var(--cor-borda);
}
.carrinho-item:last-child { border-bottom: none; }
.carrinho-item .foto {
  width: 64px; height: 64px; border-radius: var(--raio); object-fit: cover;
  background: var(--cor-fundo); display: flex; align-items: center; justify-content: center;
}
.carrinho-item .foto img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--raio); }
.carrinho-item.indisponivel { opacity: .6; }
.qt-stepper { display: inline-flex; align-items: center; gap: var(--esp-2); }
.qt-stepper button {
  width: 28px; height: 28px; border: 1px solid var(--cor-borda);
  background: var(--cor-superficie); border-radius: var(--raio); cursor: pointer; font-size: 1rem;
}
.qt-stepper button:disabled { opacity: .4; cursor: not-allowed; }
@media (min-width: 768px) {
  .layout-carrinho { grid-template-columns: 1fr 280px; align-items: start; }
}

/* ---------- Alertas ---------- */
.alerta { border-radius: var(--raio); padding: var(--esp-3) var(--esp-4); font-size: var(--texto-sm); margin-bottom: var(--esp-4); }
.alerta-info { background: var(--cor-acao-suave); color: var(--cor-acao); }
.alerta-ok { background: #E6F7EE; color: var(--cor-positivo); }
.alerta-aviso { background: #FEF3E0; color: #8a5a00; }
.alerta-erro { background: #FDE8EA; color: var(--cor-erro); }

/* ---------- Toast ---------- */
.toast-area {
  position: fixed; left: 50%; bottom: var(--esp-6); transform: translateX(-50%);
  z-index: 1000; display: flex; flex-direction: column; gap: var(--esp-2);
  width: calc(100% - var(--esp-8)); max-width: 360px;
}
.toast {
  background: var(--cor-texto); color: #fff; border-radius: var(--raio);
  padding: var(--esp-3) var(--esp-4); font-size: var(--texto-sm);
  box-shadow: var(--sombra-card-hover); animation: surge .2s ease-out;
}
.toast-erro { background: var(--cor-erro); }
.toast-ok { background: var(--cor-positivo); }
@keyframes surge { from { opacity: 0; transform: translateY(8px); } }
