/* ============================================================
   PÁGINA /PEDIDOS — FORMULÁRIO DE ENCOMENDA
   ============================================================ */
.pedido-secao {
  padding: 7rem 0 5rem;
  min-height: 100vh;
  background: var(--cor-fundo);
}
.pedido-intro {
  max-width: 640px;
  margin: 0 auto 3rem;
  text-align: center;
}
.pedido-intro .secao-titulo { margin-bottom: .75rem; }
.pedido-intro p { color: var(--cor-texto-leve); font-size: 1.05rem; }

.pedido-form-wrap {
  max-width: 760px;
  margin: 0 auto;
  background: var(--cor-branco);
  border-radius: var(--raio-lg);
  box-shadow: var(--sombra-md);
  padding: 2.5rem;
}

/* Grid dos campos */
.pedido-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
.campo-full { grid-column: 1 / -1; }

/* Campos */
.campo label {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: var(--cor-texto);
  margin-bottom: .4rem;
  letter-spacing: .2px;
}
.campo label .obrigatorio { color: var(--cor-acento); margin-left: 2px; }

.campo input,
.campo select,
.campo textarea {
  width: 100%;
  padding: .75rem 1rem;
  border: 1.5px solid var(--cor-borda);
  border-radius: var(--raio);
  font-family: var(--fonte-corpo);
  font-size: .95rem;
  color: var(--cor-texto);
  background: var(--cor-fundo);
  transition: border-color var(--transicao), box-shadow var(--transicao);
  appearance: none;
}
.campo input:focus,
.campo select:focus,
.campo textarea:focus {
  outline: none;
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 3px rgba(26,107,90,.12);
  background: var(--cor-branco);
}
.campo input.erro,
.campo select.erro,
.campo textarea.erro {
  border-color: #e53935;
  box-shadow: 0 0 0 3px rgba(229,57,53,.1);
}
.campo textarea { min-height: 100px; resize: vertical; }
.campo select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a6b63' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}
.campo-erro-msg {
  font-size: .8rem;
  color: #e53935;
  margin-top: .3rem;
  display: none;
}
.campo.tem-erro .campo-erro-msg { display: block; }

/* Radio groups */
.radio-group { display: flex; flex-wrap: wrap; gap: .75rem; }
.radio-opcao { position: relative; }
.radio-opcao input[type="radio"] { position: absolute; opacity: 0; width: 0; height: 0; }
.radio-opcao label {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .55rem 1.1rem;
  border: 1.5px solid var(--cor-borda);
  border-radius: 100px;
  cursor: pointer;
  font-size: .9rem;
  font-weight: 600;
  color: var(--cor-texto-leve);
  transition: border-color var(--transicao), color var(--transicao), background var(--transicao);
  user-select: none;
}
.radio-opcao input[type="radio"]:checked + label {
  border-color: var(--cor-primaria);
  color: var(--cor-primaria-dark);
  background: var(--cor-fundo-alt);
}
.radio-opcao label:hover {
  border-color: var(--cor-primaria);
  color: var(--cor-primaria);
}

/* Separador */
.pedido-separador {
  border: none;
  border-top: 1px solid var(--cor-borda);
  margin: 2rem 0;
}

/* Seção de grupo */
.campo-grupo-titulo {
  font-family: var(--fonte-titulo);
  font-size: 1rem;
  color: var(--cor-primaria-dark);
  font-weight: 700;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.campo-grupo-titulo::before {
  content: '';
  width: 4px;
  height: 18px;
  background: var(--cor-acento);
  border-radius: 2px;
  flex-shrink: 0;
}

/* Botão de envio */
.pedido-submit {
  display: flex;
  justify-content: center;
  margin-top: 2rem;
}
.btn-enviar {
  min-width: 220px;
  font-size: 1rem;
  padding: 1rem 2.5rem;
}

/* Mensagem de sucesso */
#pedido-sucesso {
  display: none;
  text-align: center;
  padding: 3rem 2rem;
}
.sucesso-icone {
  width: 72px; height: 72px;
  background: #e8f5e9;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
}
#pedido-sucesso h2 { color: var(--cor-primaria-dark); margin-bottom: .75rem; }
#pedido-sucesso p  { color: var(--cor-texto-leve); }
