/* ==========================================================================
   Página de Eventos (events.html)
   ========================================================================== */

/*
  1. LAYOUT GERAL E CABEÇALHOS
   ==========================================================================
*/
/*
  Os estilos dos cabeçalhos de ano e mês vêm do componente global
  .section-title em base.css. As classes abaixo são apenas para
  agrupamento semântico no HTML e não precisam de estilos.
  - .events-list
  - .year-group
  - .month-group
  - .event-items-container
*/

/* 2. ITEM DE EVENTO
   ========================================================================== */
.event-item {
  /* Layout */
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;

  /* Box Model */
  padding: 1.5rem 1rem;
  border-bottom: 1px solid var(--black);
}

.event-item:hover {
  /* Visual */
  background-color: var(--grey);
  color: var(--black);
}

/* 3. COMPONENTES DO ITEM
   ========================================================================== */

/* 3.1. Data (.event-date)
-------------------------------------------------------------------------- */
.event-date {
  /* Layout */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  /* Box Model */
  min-width: 80px;

  /* Tipografia */
  text-align: center;
}

.event-date .day {
  /* Box Model */
  display: block;

  /* Tipografia */
  font-family: var(--font-body);
  font-size: 3rem;
  line-height: 1;
  color: var(--white);

  /* Animação */
  transition: var(--transition);
}

.event-date .weekday {
  /* Box Model */
  display: block;

  /* Tipografia */
  font-size: 0.9rem;
  text-transform: uppercase;
  color: var(--grey);

  /* Animação */
  transition: var(--transition);
}

.event-item:hover .event-date .day,
.event-item:hover .event-date .weekday {
  color: var(--black);
}

/* 3.2. Detalhes (.event-details)
-------------------------------------------------------------------------- */
.event-details {
  /* Layout */
  flex-grow: 1;
}

/* --- Tipografia e Resets de Espaçamento --- */
.event-artist,
.event-artist a {
  /* Tipografia */
  color: var(--white);

  /* Animação */
  transition: var(--transition);
}

/* Sobrescreve margens globais para um alinhamento mais justo. */
.p-large.event-artist,
.p-small.event-location {
  margin: 0;
}

.event-location {
  /* Tipografia */
  color: var(--grey);

  /* Animação */
  transition: var(--transition);
}

/* --- Efeitos de Hover para Detalhes --- */
.event-item:hover .event-artist,
.event-item:hover .event-artist a {
  color: var(--black);
}
.event-artist a:hover {
  text-decoration: var(--red) underline;
}

.event-item:hover .event-location,
.event-item:hover .event-location .bullet-separator {
  color: var(--black);
}

/* 3.3. Link de Ingresso (.event-ticket-link)
-------------------------------------------------------------------------- */
.event-ticket-link {
  /* Box Model */
  min-width: 120px;

  /* Tipografia */
  text-align: right;
}

/* --- Botão de Ingresso e Status --- */
.btn-tickets,
.status-sold-out,
.status-unavailable,
.status-canceled {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  font-family: var(--font-body);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  width: 180px; /* Define uma largura fixa para garantir o mesmo tamanho */
  transition: var(--transition);
}

.btn-tickets {
  border: 1px solid var(--white);
  background-color: var(--black);
  color: var(--white);
  text-decoration: none;
}

/* Efeito de hover na linha do evento */
.event-item:hover .btn-tickets {
  background-color: var(--black);
  border-color: var(--black);
  color: var(--white);
}

/* Efeito de hover no próprio botão (sobrescreve o da linha) */
.event-item:hover .btn-tickets:hover {
  background-color: var(--grey);
  border-color: var(--black);
  color: var(--black);
}

/* --- Mensagem "Sem Ingressos" --- */
.status-unavailable {
  background-color: transparent;
  color: var(--grey);
  border: 1px solid var(--grey);
}

/* Estilo para o status "Esgotado" */
.status-sold-out {
  /* Fundo transparente com borda e texto vermelhos para indicar o status */
  background-color: transparent;
  color: var(--red);
  border: 1px solid var(--red);
}

/* Estilo para o status "Cancelado" */
.status-canceled {
  background-color: transparent;
  color: var(--red);
  border: 1px solid var(--red);
}

.event-item:hover .status-unavailable {
  color: var(--black);
  border-color: var(--black);
}

/* 4. RESPONSIVIDADE
   ========================================================================== */
@media (max-width: 768px) {
  .event-item {
    /* Layout */
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }

  .event-date {
    /* Layout */
    flex-direction: row;
    align-items: baseline;
    gap: 0.75rem;

    /* Box Model */
    min-width: auto;
  }

  .event-date .day {
    /* Tipografia */
    font-size: 2rem;
  }

  .event-ticket-link {
    /* Box Model */
    width: 100%;
    margin-top: 0.5rem;

    /* Tipografia */
    text-align: left;
  }
}
