/* =========================================================
   Portal de Agendamento Online — 4 etapas
   ========================================================= */

/* Progresso de etapas */
.etapas {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.etapa {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px;
  font-size: .82rem;
  font-weight: 500;
  color: var(--cinza-400);
  background: #fff;
  border: 1px solid var(--borda);
  margin-right: -1px;
  position: relative;
  z-index: 1;
}
.etapa:first-child { border-radius: var(--raio-md) 0 0 var(--raio-md); }
.etapa:last-child  { border-radius: 0 var(--raio-md) var(--raio-md) 0; margin-right: 0; }
.etapa.ativa {
  background: var(--cor-primaria);
  border-color: var(--cor-primaria);
  color: #fff;
  z-index: 2;
}
.etapa.concluida {
  background: var(--verde-suave);
  border-color: #6EE7B7;
  color: var(--verde);
}
.etapa-num {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem;
  font-weight: 700;
}
.etapa.concluida .etapa-num { background: var(--verde); color: #fff; }

/* Corpo do portal */
.portal-corpo {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 20px 48px;
}
.portal-secao-titulo {
  font-size: .9rem;
  font-weight: 600;
  color: var(--texto);
  margin-bottom: 14px;
}

/* Grade de seleção (serviços / profissionais) */
.grade-selecao {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px,1fr));
  gap: 10px;
  margin-bottom: 20px;
}
.cartao-selecao {
  background: #fff;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-lg);
  padding: 14px;
  cursor: pointer;
  transition: all var(--transicao);
}
.cartao-selecao:hover { border-color: var(--cor-primaria); }
.cartao-selecao.selecionado {
  border-color: var(--cor-primaria);
  background: var(--cor-primaria-suave);
}

/* Ícone de check dentro do cartão (visível só quando selecionado) */
.selecao-icone-check {
  position: absolute;
  top: 8px; right: 8px;
  color: var(--cor-primaria);
  font-size: .85rem;
  opacity: 0;
  transition: opacity var(--transicao);
}
.cartao-selecao { position: relative; }
.cartao-selecao.selecionado .selecao-icone-check { opacity: 1; }

/* Totalizador de serviços selecionados (etapa 1) */
.resumo-servicos-selecionados {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--cor-primaria-suave, #fdf0f7);
  border: 1px solid var(--cor-primaria, #e8a4c8);
  border-radius: var(--raio-md);
  padding: 10px 14px;
  font-size: .85rem;
  color: var(--texto);
  margin-bottom: 4px;
}
.resumo-servicos-selecionados i { color: var(--cor-primaria); flex-shrink: 0; }
.selecao-nome { font-weight: 600; font-size: .9rem; color: var(--texto); }
.selecao-meta { font-size: .78rem; color: var(--texto-suave); margin-top: 3px; }
.selecao-preco { font-weight: 700; color: var(--cor-primaria); margin-top: 6px; font-size: .9rem; }
.selecao-avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--cor-primaria-suave);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  margin-bottom: 8px;
  overflow: hidden;
}
.selecao-avatar img { width: 100%; height: 100%; object-fit: cover; }

/* Grade de datas */
.grade-datas {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  margin-bottom: 20px;
}
.data-btn {
  padding: 8px 4px;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-md);
  background: #fff;
  text-align: center;
  cursor: pointer;
  transition: all var(--transicao);
}
.data-btn:hover { border-color: var(--cor-primaria); }
.data-btn.selecionado { background: var(--cor-primaria); border-color: var(--cor-primaria); }
.data-dia-semana { font-size: .62rem; color: var(--cinza-400); font-weight: 600; text-transform: uppercase; display: block; }
.data-dia-num { font-size: .95rem; font-weight: 700; color: var(--texto); display: block; }
.data-btn.selecionado .data-dia-semana,
.data-btn.selecionado .data-dia-num { color: #fff; }
.data-btn.indisponivel {
  background:
    repeating-linear-gradient(
      45deg,
      var(--cinza-50),
      var(--cinza-50) 5px,
      var(--cinza-100) 5px,
      var(--cinza-100) 10px
    ) !important;
  border-color: var(--cinza-200) !important;
  pointer-events: none !important;
  cursor: not-allowed !important;
}
.data-btn.indisponivel:hover { border-color: var(--cinza-200) !important; }
.data-btn.indisponivel .data-dia-semana,
.data-btn.indisponivel .data-dia-num {
  color: var(--cinza-400) !important;
  text-decoration: line-through !important;
  text-decoration-color: var(--cinza-500) !important;
  text-decoration-thickness: 1.5px !important;
}

/* Grade de horários */
.grade-horarios {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px,1fr));
  gap: 6px;
  margin-bottom: 20px;
}
.horario-btn {
  padding: 8px;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-md);
  background: #fff;
  font-size: .85rem;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  transition: all var(--transicao);
  color: var(--texto);
}
.horario-btn:hover { border-color: var(--cor-primaria); color: var(--cor-primaria); }
.horario-btn.selecionado { background: var(--cor-primaria); border-color: var(--cor-primaria); color: #fff; }
.horario-btn.ocupado {
  background:
    repeating-linear-gradient(
      45deg,
      var(--cinza-50),
      var(--cinza-50) 5px,
      var(--cinza-100) 5px,
      var(--cinza-100) 10px
    ) !important;
  color: var(--cinza-500) !important;
  border-color: var(--cinza-200) !important;
  text-decoration: line-through !important;
  text-decoration-color: var(--vermelho) !important;
  text-decoration-thickness: 2px !important;
  pointer-events: none !important;
  cursor: not-allowed !important;
}
.horario-btn.ocupado:hover {
  border-color: var(--cinza-200) !important;
  color: var(--cinza-500) !important;
}

/* Resumo */
.resumo-box {
  background: var(--cinza-50);
  border: 1px solid var(--borda);
  border-radius: var(--raio-lg);
  padding: 14px 16px;
  margin-bottom: 18px;
}
.resumo-linha {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: .875rem;
  border-bottom: 1px solid var(--borda);
}
.resumo-linha:last-child {
  border-bottom: none;
  font-weight: 700;
  color: var(--texto);
}
.resumo-rotulo { color: var(--texto-suave); }

/* Ações das etapas */
.etapa-acoes {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--borda);
}

/* Sucesso */
.sucesso-cartao {
  text-align: center;
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: var(--raio-xl);
  padding: 40px 28px;
}
.sucesso-icone { font-size: 3rem; margin-bottom: 14px; }
.sucesso-titulo { font-size: 1.4rem; font-weight: 700; color: var(--texto); margin-bottom: 8px; }

/* Mural de login (etapa 4 sem autenticação) */
.portal-login-wall {
  text-align: center;
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: var(--raio-xl);
  padding: 36px 24px;
  margin-bottom: 20px;
}
.portal-login-wall-icone {
  font-size: 2.5rem;
  margin-bottom: 12px;
  color: var(--cor-primaria);
}
.portal-login-wall h2 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--texto);
  margin-bottom: 6px;
}
.portal-login-wall p {
  font-size: .875rem;
  color: var(--texto-suave);
  margin-bottom: 20px;
  max-width: 360px;
  margin-left: auto;
  margin-right: auto;
}
.portal-login-wall-acoes {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Carrinho de serviços (etapa 4) ──────────────────────────────────────── */
.carrinho-lista {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}
.carrinho-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  background: #fff;
  border: 1.5px solid var(--borda);
  border-radius: var(--raio-lg);
  padding: 12px 14px;
  gap: 12px;
}
.carrinho-item-info { flex: 1; min-width: 0; }
.carrinho-item-nome { font-weight: 600; font-size: .9rem; color: var(--texto); margin-bottom: 5px; }
.carrinho-item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: .78rem;
  color: var(--texto-suave);
}
.carrinho-item-meta span { display: flex; align-items: center; gap: 4px; }
.carrinho-item-direita {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}
.carrinho-item-preco {
  font-weight: 700;
  color: var(--cor-primaria);
  font-size: .9rem;
}
.carrinho-item-remover {
  background: none;
  border: none;
  color: var(--cinza-400);
  cursor: pointer;
  padding: 2px 5px;
  border-radius: var(--raio-md);
  transition: color var(--transicao);
  font-size: .85rem;
  line-height: 1;
}
.carrinho-item-remover:hover { color: var(--vermelho); }
.carrinho-total-linha {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  background: var(--cinza-50);
  border: 1px solid var(--borda);
  border-radius: var(--raio-md);
  font-size: .9rem;
  font-weight: 700;
  color: var(--texto);
  margin-bottom: 14px;
}
.btn-adicionar-servico {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px dashed var(--cor-primaria);
  border-radius: var(--raio-lg);
  background: transparent;
  color: var(--cor-primaria);
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transicao);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  margin-bottom: 20px;
}
.btn-adicionar-servico:hover { background: var(--cor-primaria-suave, #fdf0f7); }

/* Responsivo */
@media (max-width: 600px) {
  .grade-selecao { grid-template-columns: 1fr 1fr; }
  .grade-datas   { grid-template-columns: repeat(4,1fr); }
  .etapas        { gap: 4px; }
  .etapa { border-radius: var(--raio-md) !important; font-size: .75rem; padding: 6px 10px; }
}
