/* Estilos para o componente de abas (tabs)
 * Implementa: navegação por abas, indicador dinâmico e conteúdo alternável
 * Utiliza pseudo-elementos para criar o indicador de aba ativa
 */
.tabs {
  margin: 0 auto;
  max-width: 800px;
  background-color: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

/* Cabeçalho das abas com indicador dinâmico */
.tabs-header {
  display: flex;
  background-color: var(--gray-100);
  position: relative;
}

.tabs-header::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: 2px;
  background-color: var(--accent);
  transition: all 0.3s ease;
}

/* Posicionamento do indicador baseado na aba ativa */
.tabs-header[data-active="tab1"]::after {
  left: 0;
  width: 33.33%;
}

.tabs-header[data-active="tab2"]::after {
  left: 33.33%;
  width: 33.33%;
}

.tabs-header[data-active="tab3"]::after {
  left: 66.66%;
  width: 33.33%;
}

/* Botões das abas */
.tab-button {
  flex: 1;
  padding: var(--spacing-md);
  cursor: pointer;
  background-color: transparent;
  color: var(--gray-700);
  transition: var(--transition-fast);
  border: none;
  font-weight: 500;
  font-size: var(--font-size-base);
}

.tab-button:hover {
  color: var(--accent);
}

.tab-button.active {
  color: var(--accent);
  font-weight: 600;
}

/* Conteúdo das abas */
.tab-content {
  padding: var(--spacing-xl);
  display: none;
  color: var(--gray-600);
  font-size: var(--font-size-base);
}

.tab-content.active {
  display: block;
}

.tab-content h3 {
  font-size: var(--font-size-xl);
  margin-bottom: var(--spacing-sm);
  color: var(--gray-800);
}

/* Responsividade */
@media (max-width: 992px) {
  .tabs {
    max-width: 90%;
  }
}