/* ============================================================
   EXC Rio · Formulário de qualificação multi-etapas
   Identidade do site (Cormorant + DM Sans). Tema claro (Social)
   e escuro (Corporativo) via [data-theme]. Escopo: #qualificacao
   ------------------------------------------------------------
   IMPORTANTE: as LPs aplicam "#exc-lp *{margin:0!important;
   padding:0!important}" — um seletor com ID (especificidade 1,0,0).
   Por isso TODAS as regras abaixo são prefixadas com #qualificacao
   (especificidade >= 1,1,0) E usam !important nos espaçamentos,
   garantindo que vençam o reset da página.
   ============================================================ */

#qualificacao{
  --qz-text:#111;
  --qz-muted:#9a9a9a;
  --qz-faint:#bdbdbd;
  --qz-line:#d6d6d2;
  --qz-border:#e0e0db;
  --qz-card:#ffffff;
  --qz-card-hover:#fafafa;
  --qz-sel-bg:rgba(0,0,0,.045);
  --qz-sel-border:#111;
  --qz-track:#e6e6e2;
  --qz-fill:#111;
  --qz-btn-bg:#111;
  --qz-btn-fg:#fff;
  --qz-btn-bg-hover:#333;
  --qz-ok:#0d7c5a;
  --qz-bad:#c03030;

  font-family:'DM Sans',sans-serif;
  color:var(--qz-text);
  width:100%;
  max-width:100%;
  margin:0 auto !important;
  text-align:left;
}
#qualificacao *{box-sizing:border-box}

#qualificacao[data-theme="dark"]{
  --qz-text:#ececec;
  --qz-muted:#8a8a8a;
  --qz-faint:#666;
  --qz-line:#333;
  --qz-border:#2a2a2a;
  --qz-card:#141414;
  --qz-card-hover:#1a1a1a;
  --qz-sel-bg:rgba(255,255,255,.06);
  --qz-sel-border:#ececec;
  --qz-track:#262626;
  --qz-fill:#ececec;
  --qz-btn-bg:#fff;
  --qz-btn-fg:#0a0a0a;
  --qz-btn-bg-hover:#dcdcdc;
  --qz-ok:#4fd1a5;
  --qz-bad:#ff6b6b;
}

/* elementos com atributo hidden permanecem ocultos */
#qualificacao [hidden]{display:none !important}

/* ---------- Progresso ---------- */
#qualificacao .qz-progress{margin:0 0 34px !important}
#qualificacao .qz-progress-head{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:var(--qz-muted);margin:0 0 10px !important;
}
#qualificacao .qz-progress-step{color:var(--qz-text);font-weight:500}
#qualificacao .qz-progress-track{height:2px;background:var(--qz-track);width:100%;overflow:hidden}
#qualificacao .qz-progress-fill{
  height:100%;width:25%;background:var(--qz-fill);
  transition:width .35s cubic-bezier(.4,0,.2,1);
}

/* ---------- Etapas (reset do <fieldset>) ---------- */
#qualificacao .qz-step{display:none;border:0 !important;margin:0 !important;padding:0 !important;min-width:0 !important}
#qualificacao .qz-step.is-active{display:block;animation:qz-in .35s ease}
@keyframes qz-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

#qualificacao .qz-step-title{
  font-family:'Cormorant',serif;font-weight:300;
  font-size:clamp(24px,3.5vw,32px);line-height:1.2;
  margin:0 0 28px !important;color:var(--qz-text);outline:none;
}

/* ---------- Campos ---------- */
#qualificacao .qz-field{margin:0 0 26px !important}
#qualificacao .qz-field:last-child{margin-bottom:0 !important}
#qualificacao .qz-label{
  display:block;font-size:10px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;color:var(--qz-muted);margin:0 0 10px !important;
}
#qualificacao .qz-req{color:var(--qz-faint);margin:0 0 0 2px !important}

#qualificacao .qz-input{
  width:100%;font-family:'DM Sans',sans-serif;font-size:15px;
  color:var(--qz-text);background:transparent;border:none;
  border-bottom:1px solid var(--qz-line) !important;border-radius:0;
  padding:10px 0 !important;outline:none;transition:border-color .15s;
}
#qualificacao .qz-input::placeholder{color:var(--qz-faint)}
#qualificacao .qz-input:focus{border-bottom-color:var(--qz-text) !important}

/* campo de data (calendário nativo) */
#qualificacao .qz-date{cursor:pointer;color:var(--qz-text);min-height:41px}
#qualificacao .qz-date:not(:focus):invalid,
#qualificacao .qz-date[value=""]{color:var(--qz-faint)}
#qualificacao .qz-date::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6}
#qualificacao .qz-date:hover::-webkit-calendar-picker-indicator{opacity:1}
/* no tema escuro, inverte o ícone do calendário para ficar visível */
#qualificacao[data-theme="dark"] .qz-date::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.55}
#qualificacao[data-theme="dark"] .qz-date:hover::-webkit-calendar-picker-indicator{opacity:.9}

/* ---------- Opções (radio cards) ---------- */
#qualificacao .qz-options{display:flex;flex-direction:column;gap:7px}
#qualificacao .qz-options.qz-cols{display:grid;grid-template-columns:1fr 1fr;gap:7px}
#qualificacao .qz-option{
  position:relative;display:flex;align-items:center;gap:11px;
  background:var(--qz-card);border:1px solid var(--qz-border);
  border-radius:8px;padding:12px 14px !important;cursor:pointer;
  font-size:14px;color:var(--qz-text);transition:background .15s,border-color .15s;
}
#qualificacao .qz-option:hover{background:var(--qz-card-hover);border-color:var(--qz-faint)}
#qualificacao .qz-option input{position:absolute;opacity:0;width:0;height:0;margin:0 !important}
#qualificacao .qz-option-mark{
  flex-shrink:0;width:16px;height:16px;border-radius:50%;
  border:1.5px solid var(--qz-faint);display:flex;
  align-items:center;justify-content:center;transition:border-color .15s;
}
#qualificacao .qz-option-mark::after{content:"";width:8px;height:8px;border-radius:50%;background:transparent;transition:background .15s}
#qualificacao .qz-option.is-selected{border-color:var(--qz-sel-border);background:var(--qz-sel-bg);font-weight:500}
#qualificacao .qz-option.is-selected .qz-option-mark{border-color:var(--qz-sel-border)}
#qualificacao .qz-option.is-selected .qz-option-mark::after{background:var(--qz-sel-border)}
/* opção que reprova o lead (orçamento abaixo do mínimo) */
#qualificacao .qz-option.is-selected[data-disqualify="true"]{border-color:var(--qz-bad);background:rgba(192,48,48,.06)}
#qualificacao .qz-option.is-selected[data-disqualify="true"] .qz-option-mark{border-color:var(--qz-bad)}
#qualificacao .qz-option.is-selected[data-disqualify="true"] .qz-option-mark::after{background:var(--qz-bad)}
#qualificacao .qz-option:focus-within{box-shadow:0 0 0 3px var(--qz-sel-bg)}

/* texto de apoio sob um rótulo */
#qualificacao .qz-help{font-size:12px;color:var(--qz-muted);line-height:1.5;margin:-3px 0 12px !important}
#qualificacao .qz-optional{color:var(--qz-faint);font-weight:400;letter-spacing:1px}

/* subcampo condicional ("Outro") */
#qualificacao .qz-subfield{margin:8px 0 0 !important;display:none}
#qualificacao .qz-subfield.is-visible{display:block}
#qualificacao .qz-subfield .qz-input{font-size:14px}
#qualificacao .qz-options.qz-cols .qz-subfield{grid-column:1/-1}

/* erro de validação */
#qualificacao .qz-error{
  display:none;margin:9px 0 0 !important;font-size:12px;color:var(--qz-bad);letter-spacing:.3px;
}
#qualificacao .qz-error.is-visible{display:block}

/* ---------- Navegação ---------- */
#qualificacao .qz-nav{display:flex;align-items:center;gap:12px;margin:34px 0 0 !important}
#qualificacao .qz-btn{
  font-family:'DM Sans',sans-serif;font-size:11px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;cursor:pointer;
  border-radius:0;transition:background .15s,color .15s,border-color .15s;
}
#qualificacao .qz-btn-primary{
  background:var(--qz-btn-bg);color:var(--qz-btn-fg);border:none;
  padding:16px 36px !important;flex:1;display:inline-flex;align-items:center;
  justify-content:center;gap:8px;
}
#qualificacao .qz-btn-primary:hover{background:var(--qz-btn-bg-hover)}
#qualificacao .qz-btn-ghost{
  background:transparent;color:var(--qz-muted);
  border:1px solid var(--qz-border);padding:15px 22px !important;
}
#qualificacao .qz-btn-ghost:hover{color:var(--qz-text);border-color:var(--qz-faint)}
#qualificacao .qz-btn svg{width:13px;height:13px}

/* ---------- Revisão ---------- */
#qualificacao .qz-review-list{border-top:1px solid var(--qz-border);margin:4px 0 0 !important}
#qualificacao .qz-review-row{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:14px;padding:13px 0 !important;border-bottom:1px solid var(--qz-border);
}
#qualificacao .qz-review-k{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--qz-muted);flex-shrink:0;padding:2px 0 0 !important}
#qualificacao .qz-review-v{font-size:14px;text-align:right;color:var(--qz-text)}
#qualificacao .qz-review-edit{
  display:inline-block;margin:0 0 0 10px !important;font-size:10px;letter-spacing:1px;
  text-transform:uppercase;color:var(--qz-muted);text-decoration:underline;
  cursor:pointer;background:none;border:none;font-family:inherit;
}
#qualificacao .qz-review-edit:hover{color:var(--qz-text)}

/* ---------- Telas de resultado (descarte / sucesso) ---------- */
#qualificacao .qz-screen{display:none;text-align:center;padding:18px 0 8px !important}
#qualificacao .qz-screen.is-active{display:block;animation:qz-in .4s ease}
#qualificacao .qz-screen-icon{
  width:56px;height:56px;border-radius:50%;margin:0 auto 20px !important;
  display:flex;align-items:center;justify-content:center;font-size:24px;line-height:1;
}
#qualificacao .qz-screen-icon.ok{background:rgba(13,124,90,.1);color:var(--qz-ok);border:1px solid rgba(13,124,90,.25)}
#qualificacao .qz-screen-icon.info{background:rgba(0,0,0,.04);color:var(--qz-text);border:1px solid var(--qz-border)}
#qualificacao[data-theme="dark"] .qz-screen-icon.info{background:rgba(255,255,255,.05)}
#qualificacao .qz-screen-title{font-family:'Cormorant',serif;font-weight:300;font-size:clamp(26px,4vw,34px);line-height:1.15;margin:0 0 14px !important;color:var(--qz-text)}
#qualificacao .qz-screen-text{font-size:14px;line-height:1.7;color:var(--qz-muted);max-width:400px;margin:0 auto 22px !important}
#qualificacao .qz-venues{
  list-style:none;padding:0 !important;margin:0 auto 24px !important;max-width:380px;
  text-align:left;border-top:1px solid var(--qz-border);
}
#qualificacao .qz-venues li{
  display:flex;justify-content:space-between;gap:10px;padding:11px 0 !important;
  border-bottom:1px solid var(--qz-border);font-size:14px;color:var(--qz-text);
}
#qualificacao .qz-venues li span{color:var(--qz-muted);font-size:12px}
#qualificacao .qz-restart{
  background:transparent;border:1px solid var(--qz-border);color:var(--qz-muted);
  font-family:'DM Sans',sans-serif;font-size:11px;letter-spacing:2px;
  text-transform:uppercase;padding:13px 26px !important;cursor:pointer;transition:background .15s,color .15s,border-color .15s;
}
#qualificacao .qz-restart:hover{color:var(--qz-text);border-color:var(--qz-faint)}

/* ---------- Responsivo ---------- */
@media (max-width:480px){
  #qualificacao .qz-options.qz-cols{grid-template-columns:1fr}
  #qualificacao .qz-nav{flex-wrap:wrap}
  #qualificacao .qz-btn-primary{order:-1;width:100%;flex:none}
  #qualificacao .qz-btn-ghost{width:100%}
}
