/* =========================================================
   Feira de Livros SESC — componentes
   Usa as variáveis definidas em style.css (:root).
   ========================================================= */

.feira-vazio { color: var(--feira-texto-suave); font-style: italic; }

/* ---------------- Contagem regressiva ---------------- */
.feira-contagem { text-align: center; }
.feira-contagem-blocos {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}
.feira-contagem-bloco {
  background: var(--feira-azul, var(--sesc-azul));
  color: #fff; border-radius: var(--feira-raio);
  min-width: 78px; padding: 14px 10px;
}
.feira-contagem-bloco strong {
  display: block; font-family: var(--feira-fonte-titulo);
  font-size: 2rem; line-height: 1; font-weight: 800;
}
.feira-contagem-bloco span {
  font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; opacity: .85;
}
.feira-contagem-rotulo { margin-top: 10px; color: var(--feira-texto-suave); }

/* ---------------- Filtros da grade ---------------- */
.feira-grade { max-width: var(--feira-container); margin: 0 auto; }
.feira-filtros {
  display: flex; flex-direction: column; gap: 14px;
  margin-bottom: 28px; padding-bottom: 22px;
  border-bottom: 1px solid var(--feira-borda);
}
.feira-filtro-grupo { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.feira-filtro-titulo {
  font-family: var(--feira-fonte-titulo); font-weight: 700;
  font-size: .78rem; text-transform: uppercase; letter-spacing: .07em;
  color: var(--feira-texto-suave); margin-right: 6px; min-width: 58px;
}
.feira-chip {
  border: 1px solid var(--feira-borda); background: var(--feira-branco);
  color: var(--feira-texto); border-radius: 999px;
  padding: 7px 16px; font-size: .9rem; cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
}
.feira-chip:hover { border-color: var(--feira-acento); }
.feira-chip.is-ativo {
  background: var(--feira-acento); border-color: var(--feira-acento); color: #fff;
}

/* ---------------- Dia / sessões ---------------- */
.feira-dia { margin-bottom: 36px; }
.feira-dia-titulo {
  font-family: var(--feira-fonte-titulo); font-weight: 800;
  font-size: 1.4rem; color: var(--sesc-azul);
  border-left: 5px solid var(--sesc-amarelo);
  padding-left: 12px; margin-bottom: 18px; text-transform: capitalize;
}
.feira-sessoes { display: flex; flex-direction: column; gap: 12px; }
.feira-sessao {
  display: flex; gap: 18px; align-items: flex-start;
  background: var(--feira-branco); border: 1px solid var(--feira-borda);
  border-radius: var(--feira-raio); padding: 16px 18px;
  box-shadow: var(--feira-sombra);
}
.feira-sessao-hora {
  flex: 0 0 84px; font-family: var(--feira-fonte-titulo); font-weight: 700;
  font-size: 1.05rem; color: var(--feira-acento); line-height: 1.3;
}
.feira-sessao-hora span { display: block; font-size: .82rem; color: var(--feira-texto-suave); font-weight: 600; }
.feira-sessao-corpo { flex: 1; }
.feira-sessao-espaco {
  display: inline-block; font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--sesc-azul); margin-bottom: 3px;
}
.feira-sessao-titulo { font-size: 1.1rem; margin: 2px 0 4px; line-height: 1.25; }
.feira-sessao-titulo a { color: var(--feira-texto); text-decoration: none; }
.feira-sessao-titulo a:hover { color: var(--feira-acento); }
.feira-sessao-pal { color: var(--feira-texto-suave); font-size: .92rem; margin: 0 0 6px; }
.feira-sessao-tag {
  display: inline-block; font-size: .72rem; font-weight: 600;
  background: var(--feira-fundo-suave); color: var(--feira-texto-suave);
  padding: 3px 10px; border-radius: 999px;
}
.feira-sem-resultado { text-align: center; color: var(--feira-texto-suave); padding: 30px 0; }

/* ---------------- Grid de palestrantes ---------------- */
.feira-palestrantes-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 24px;
}
.feira-palestrante-card { text-decoration: none; color: var(--feira-texto); text-align: center; display: block; }
.feira-palestrante-foto {
  aspect-ratio: 1 / 1; border-radius: var(--feira-raio); overflow: hidden;
  background: var(--feira-fundo-suave); margin-bottom: 12px;
}
.feira-palestrante-foto img { width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .3s; }
.feira-palestrante-card:hover .feira-palestrante-foto img { transform: scale(1.05); }
.feira-foto-placeholder { display: block; width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--sesc-azul), var(--feira-acento)); opacity: .18; }
.feira-palestrante-nome { font-size: 1.05rem; margin: 0 0 2px; }
.feira-palestrante-sub { color: var(--feira-texto-suave); font-size: .85rem; margin: 0; }

/* ---------------- Single palestrante ---------------- */
.feira-single { max-width: var(--feira-container); margin: 0 auto; padding: 40px 20px; }
.feira-split { display: grid; grid-template-columns: 320px 1fr; gap: 40px; align-items: start; }
.feira-split .feira-split-foto img { width: 100%; border-radius: var(--feira-raio); }
.feira-single h1 { font-family: var(--feira-fonte-titulo); color: var(--sesc-azul); margin: 0 0 6px; }
.feira-single .feira-sub { color: var(--feira-acento); font-weight: 600; margin: 0 0 18px; }
.feira-links a { display: inline-block; margin-right: 14px; color: var(--sesc-azul); font-weight: 600; }
.feira-sessoes-do-palestrante { margin-top: 36px; }
.feira-sessoes-do-palestrante h2 { font-family: var(--feira-fonte-titulo); color: var(--sesc-azul); }

/* ---------------- Responsivo ---------------- */
@media (max-width: 768px) {
  .feira-split { grid-template-columns: 1fr; }
  .feira-sessao { flex-direction: column; gap: 8px; }
  .feira-sessao-hora { flex-basis: auto; }
}
