/* ═══════════════════════════════════════════════
   PADRÃO ÍMPAR — Formulários e Resultados
   Base: imagem/teste-estilo-impar-4.html
   Inclua este arquivo em todos os HTMLs do projeto.
   ═══════════════════════════════════════════════ */

/* FONTES — garante que estejam disponíveis */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,300;0,400;0,500;0,600;1,400;1,500&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ── INPUTS, TEXTAREAS, SELECTS ── */
input[type="text"],
input[type="number"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="url"],
textarea,
select {
  background: #FFFFFF !important;
  border: 1px solid #E2D9C8 !important;
  border-radius: 4px !important;
  font-family: "Playfair Display", serif !important;
  font-size: 16px !important;
  font-weight: 300 !important;
  color: #2C2118 !important;
  padding: 12px 14px !important;
  outline: none !important;
  transition: border-color .2s, box-shadow .2s !important;
  line-height: 1.6 !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus {
  border-color: #C3AC9D !important;
  box-shadow: 0 0 0 3px rgba(195,172,157,.08) !important;
}

input::placeholder,
textarea::placeholder {
  font-family: "DM Sans", sans-serif !important;
  font-size: 14px !important;
  color: rgba(44,33,24,.4) !important;
  font-style: italic !important;
}

textarea {
  resize: vertical !important;
  min-height: 80px !important;
}

/* ── LABELS ── */
label,
.campo-label,
.lbl,
.chave-label,
.field-label,
.flbl {
  font-family: "DM Sans", sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #2C2118 !important;
  letter-spacing: .3px !important;
  display: block !important;
  margin-bottom: 8px !important;
  line-height: 1.5 !important;
}

.lbl-hint,
.campo-label span,
.field-hint {
  font-size: 12px !important;
  color: #666666 !important;
  font-weight: 300 !important;
}

/* ── WRAPPER DE CAMPO ── */
.campo-wrap,
.field-wrap,
.form-group {
  margin-bottom: 22px !important;
}

/* ── BOTÃO PRIMÁRIO ── */
.btn-pri,
.btn-next,
.bnext,
.btn-primary,
.btn-submit,
.btn-gerar,
button[type="submit"] {
  background: linear-gradient(135deg, #A18570, #C3AC9D) !important;
  color: #0D0D0D !important;
  border: none !important;
  padding: 14px 32px !important;
  font-family: "DM Sans", sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: opacity .2s !important;
  border-radius: 0 !important;
}

.btn-pri:hover,
.btn-next:hover,
.bnext:hover,
.btn-primary:hover,
.btn-submit:hover,
.btn-gerar:hover,
button[type="submit"]:hover {
  opacity: .88 !important;
}

/* ── BOTÃO SECUNDÁRIO ── */
.btn-sec,
.btn-prev,
.bprev,
.btn-secondary,
.btn-voltar {
  background: transparent !important;
  color: #2C2118 !important;
  border: 1px solid rgba(17,17,17,.4) !important;
  padding: 14px 20px !important;
  font-family: "DM Sans", sans-serif !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all .2s !important;
  border-radius: 0 !important;
}

.btn-sec:hover,
.btn-prev:hover,
.bprev:hover,
.btn-secondary:hover,
.btn-voltar:hover {
  border-color: rgba(195,172,157,.45) !important;
  color: #333333 !important;
}

/* ── LINHA DE BOTÕES ── */
.btn-row,
.btn-group,
.nav-btns {
  display: flex !important;
  gap: 10px !important;
  margin-top: 36px !important;
}

/* ── BARRA DE PROGRESSO ── */
.prog-bar,
.progress-bar {
  height: 1px !important;
  background: rgba(17,17,17,.4) !important;
}

.prog-fill,
.progress-fill {
  height: 100% !important;
  background: linear-gradient(90deg, #A18570, #C3AC9D) !important;
  transition: width .5s ease !important;
}

.prog-etapa,
.progress-label {
  font-size: 12px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: #C3AC9D !important;
  font-weight: 500 !important;
  font-family: "DM Sans", sans-serif !important;
}

/* ── TÍTULO DE ETAPA ── */
.etapa-titulo,
.step-title,
.form-titulo {
  font-family: "Playfair Display", serif !important;
  font-size: 24px !important;
  font-weight: 300 !important;
  color: #1A1512 !important;
  margin-bottom: 4px !important;
}

.etapa-sub,
.step-sub,
.form-sub {
  font-size: 13px !important;
  color: #2C2118 !important;
  margin-bottom: 32px !important;
  line-height: 1.6 !important;
  font-family: "DM Sans", sans-serif !important;
}

/* ── RESULTADO — CABEÇALHO ── */
.rel-hdr {
  text-align: center !important;
  padding: 44px 0 36px !important;
  border-bottom: 1px solid rgba(17,17,17,.4) !important;
  margin-bottom: 44px !important;
}

.rel-tag {
  font-size: 10px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  color: #C3AC9D !important;
  margin-bottom: 10px !important;
  font-family: "DM Sans", sans-serif !important;
  display: block !important;
}

.rel-nome {
  font-family: "Playfair Display", serif !important;
  font-size: clamp(26px,5vw,44px) !important;
  font-weight: 300 !important;
  color: #1A1512 !important;
  line-height: 1.1 !important;
  margin-bottom: 8px !important;
}

.rel-tagline {
  font-family: "Playfair Display", serif !important;
  font-size: 16px !important;
  font-style: italic !important;
  color: #A18570 !important;
  margin-bottom: 8px !important;
}

.rel-sub {
  font-size: 13px !important;
  color: #2C2118 !important;
  font-family: "DM Sans", sans-serif !important;
}

/* ── RESULTADO — SEÇÕES ── */
.sec { margin-bottom: 40px !important; }

.sec-n {
  font-size: 10px !important;
  letter-spacing: 4px !important;
  color: #C3AC9D !important;
  text-transform: uppercase !important;
  margin-bottom: 4px !important;
  font-family: "DM Sans", sans-serif !important;
  display: block !important;
}

.sec-t {
  font-family: "Playfair Display", serif !important;
  font-size: 22px !important;
  font-weight: 400 !important;
  color: #1A1512 !important;
  margin-bottom: 16px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid rgba(195,172,157,.1) !important;
}

.divider {
  border: none !important;
  border-top: 1px solid rgba(195,172,157,.1) !important;
  margin: 32px 0 !important;
}

/* ── RESULTADO — TEXTO CORRIDO ── */
.corpo {
  font-size: 15px !important;
  line-height: 1.85 !important;
  color: #333333 !important;
  font-family: "DM Sans", sans-serif !important;
}

.corpo p { margin-bottom: 10px !important; }

/* ── RESULTADO — CARDS ── */
.card {
  background: rgba(195,172,157,.04) !important;
  border: 1px solid rgba(195,172,157,.1) !important;
  padding: 15px !important;
}

.card-t {
  font-size: 10px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  margin-bottom: 9px !important;
  font-family: "DM Sans", sans-serif !important;
  font-weight: 500 !important;
}

.card-t.ouro { color: #C3AC9D !important; }
.card-t.cinza { color: #2C2118 !important; }

.card p,
.card ul {
  font-size: 13px !important;
  color: #333333 !important;
  line-height: 1.75 !important;
  font-family: "DM Sans", sans-serif !important;
}

.card ul { list-style: none !important; padding: 0 !important; }
.card ul li::before { content: "— " !important; color: rgba(195,172,157,.5) !important; }

/* ── RESULTADO — BARRAS ── */
.barra { margin-bottom: 13px !important; }

.barra-label {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 12px !important;
  margin-bottom: 5px !important;
  font-family: "DM Sans", sans-serif !important;
}

.barra-label strong { color: #A18570 !important; font-weight: 500 !important; }
.barra-label span { color: #C3AC9D !important; font-weight: 500 !important; }
.barra-track { height: 2px !important; background: rgba(195,172,157,.1) !important; }
.barra-fill { height: 100% !important; background: linear-gradient(90deg, #A18570, #C3AC9D) !important; }

/* ── RESULTADO — ALERTA / DESTAQUE ── */
.alerta {
  background: rgba(195,172,157,.05) !important;
  border-left: 2px solid #C3AC9D !important;
  padding: 12px 15px !important;
  margin-top: 14px !important;
}

.alerta p {
  font-size: 13px !important;
  color: #333333 !important;
  line-height: 1.7 !important;
}

/* ── RESULTADO — AÇÕES NUMERADAS ── */
.cal-item {
  padding: 11px 12px 11px 46px !important;
  position: relative !important;
  border-left: 1px solid rgba(17,17,17,.4) !important;
  margin-bottom: 8px !important;
  font-size: 13px !important;
  color: #333333 !important;
  line-height: 1.6 !important;
  font-family: "DM Sans", sans-serif !important;
}

.cal-num {
  position: absolute !important;
  left: 12px !important;
  top: 11px !important;
  font-family: "Playfair Display", serif !important;
  font-size: 18px !important;
  color: #C3AC9D !important;
}

/* ── RESULTADO — MENSAGEM FINAL ── */
.msg-box {
  background: linear-gradient(135deg,rgba(195,172,157,.07),rgba(195,172,157,.03)) !important;
  border: 1px solid rgba(17,17,17,.4) !important;
  padding: 28px !important;
  text-align: center !important;
  margin-top: 40px !important;
}

.msg-txt {
  font-family: "Playfair Display", serif !important;
  font-size: 18px !important;
  font-style: italic !important;
  color: #1A1512 !important;
  line-height: 1.6 !important;
  margin-bottom: 14px !important;
}

.msg-assin {
  font-size: 10px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: #C3AC9D !important;
  font-family: "DM Sans", sans-serif !important;
}

/* ── BOTÃO IMPRIMIR / SALVAR ── */
.imprimir {
  display: block !important;
  width: 100% !important;
  background: transparent !important;
  border: 1px solid rgba(195,172,157,.3) !important;
  color: #A18570 !important;
  padding: 13px !important;
  font-family: "DM Sans", sans-serif !important;
  font-size: 10px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  margin-top: 18px !important;
  border-radius: 0 !important;
}

.imprimir:hover { background: rgba(195,172,157,.05) !important; }

/* ── ERRO ── */
.err-box,
.erro-box,
.alert-erro {
  background: rgba(180,60,60,.1) !important;
  border: 1px solid rgba(180,60,60,.3) !important;
  padding: 13px 15px !important;
  font-size: 13px !important;
  color: #E8A0A0 !important;
  line-height: 1.6 !important;
  margin-bottom: 16px !important;
  font-family: "DM Sans", sans-serif !important;
}

/* ── LOADING ── */
.loading-txt {
  font-family: "Playfair Display", serif !important;
  font-size: 20px !important;
  color: #1A1512 !important;
  margin-bottom: 8px !important;
}

.loading-sub {
  font-size: 12px !important;
  color: #2C2118 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  font-family: "DM Sans", sans-serif !important;
}
