:root {
  --d: #E2483D;   /* Dominante  - vermelho */
  --i: #F2A93B;   /* Influente  - amarelo  */
  --s: #3FA66A;   /* Estavel    - verde    */
  --c: #3B7DD8;   /* Conforme   - azul     */
  --tinta: #1d2330;
  --tinta-suave: #5b6472;
  --linha: #e6e9ef;
  --fundo: #f5f7fb;
  --card: #ffffff;
  --sombra: 0 4px 24px rgba(29,35,48,.07);
  --radius: 16px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--fundo);
  color: var(--tinta);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
.wrap { max-width: 860px; margin: 0 auto; padding: 32px 20px 80px; }
.wrap-lg { max-width: 1040px; }
a { color: var(--c); }

.card {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--sombra);
  padding: 32px;
  margin-bottom: 20px;
}
h1 { font-size: 28px; line-height: 1.25; margin-bottom: 10px; }
h2 { font-size: 21px; margin: 28px 0 12px; }
h3 { font-size: 16px; margin: 18px 0 6px; color: var(--tinta-suave); text-transform: uppercase; letter-spacing: .04em; }
p { margin-bottom: 12px; }
.muted { color: var(--tinta-suave); }
.center { text-align: center; }

label { display: block; font-weight: 600; margin: 14px 0 6px; }
input[type=text], input[type=email], input[type=tel], input[type=password], select {
  width: 100%; padding: 14px 16px; font-size: 17px;
  border: 1.5px solid var(--linha); border-radius: 12px; background: #fff;
}
input:focus, select:focus { outline: none; border-color: var(--c); }

.btn {
  display: inline-block; background: var(--tinta); color: #fff; border: none;
  padding: 15px 28px; font-size: 17px; font-weight: 600; border-radius: 12px;
  cursor: pointer; text-decoration: none; transition: transform .08s ease, opacity .2s;
}
.btn:hover { opacity: .92; }
.btn:active { transform: translateY(1px); }
.btn-bloco { width: 100%; text-align: center; }
.btn-ghost { background: #fff; color: var(--tinta); border: 1.5px solid var(--linha); }
.btn[disabled] { opacity: .4; cursor: not-allowed; }

/* avatar / sigla */
.sigla {
  display: inline-flex; align-items: center; justify-content: center;
  width: 84px; height: 84px; border-radius: 22px; color: #fff;
  font-size: 34px; font-weight: 800; letter-spacing: .02em;
}
.fc-D { background: var(--d); } .fc-I { background: var(--i); }
.fc-S { background: var(--s); } .fc-C { background: var(--c); }
.bg-D { background: var(--d); } .bg-I { background: var(--i); }
.bg-S { background: var(--s); } .bg-C { background: var(--c); }
.txt-D { color: var(--d); } .txt-I { color: var(--i); }
.txt-S { color: var(--s); } .txt-C { color: var(--c); }

/* barras de fator */
.fator-row { display: grid; grid-template-columns: 130px 1fr 70px; align-items: center; gap: 12px; margin: 10px 0; }
.fator-nome { font-weight: 600; }
.barra { height: 14px; border-radius: 8px; background: var(--linha); overflow: hidden; }
.barra > span { display: block; height: 100%; border-radius: 8px; }
.fator-val { text-align: right; font-weight: 700; }
.nivel-tag { font-size: 12px; color: var(--tinta-suave); }

/* badges */
.badge { display: inline-block; padding: 4px 12px; border-radius: 999px; font-size: 13px; font-weight: 600; }
.badge-completo { background: #eef4ff; color: var(--c); }
.badge-rapido { background: #fff4e6; color: #c47a12; }
.status { font-size: 13px; font-weight: 600; }
.status-pendente { color: var(--tinta-suave); }
.status-respondendo { color: var(--i); }
.status-concluido { color: var(--s); }

/* tabela painel */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 12px 10px; border-bottom: 1px solid var(--linha); font-size: 15px; }
th { font-size: 13px; text-transform: uppercase; letter-spacing: .04em; color: var(--tinta-suave); }

/* perguntas */
.progresso { position: sticky; top: 0; background: var(--fundo); padding: 16px 0; z-index: 5; }
.progresso .barra { height: 8px; }
.bloco { animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.opcoes { margin: 22px 0; }
.opcao {
  display: grid; grid-template-columns: 70px 1fr 70px; align-items: center; gap: 10px;
  padding: 12px 14px; border: 1.5px solid var(--linha); border-radius: 14px; margin-bottom: 10px;
}
.opcao .palavra { font-size: 19px; font-weight: 600; text-align: center; }
.pick { border: none; background: #f0f2f7; border-radius: 10px; padding: 10px 0; font-weight: 700; cursor: pointer; font-size: 13px; color: var(--tinta-suave); }
.pick.mais.on { background: var(--s); color: #fff; }
.pick.menos.on { background: var(--d); color: #fff; }
.hint { font-size: 14px; color: var(--tinta-suave); margin-bottom: 4px; }

/* secoes resultado */
.secao { padding: 16px 0; border-bottom: 1px solid var(--linha); }
.secao:last-child { border-bottom: none; }
.chips span { display: inline-block; background: #f0f2f7; padding: 6px 14px; border-radius: 999px; margin: 0 8px 8px 0; font-weight: 600; font-size: 14px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.talento { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px dashed var(--linha); }
.talento b { font-weight: 600; }
@media (max-width: 640px) {
  .grid2 { grid-template-columns: 1fr; }
  .fator-row { grid-template-columns: 96px 1fr 54px; }
  .opcao { grid-template-columns: 56px 1fr 56px; }
  .opcao .palavra { font-size: 17px; }
}
/* topicos do teste rapido */
.topico { border: 1.5px solid var(--linha); border-left-width: 5px; border-radius: 12px; padding: 16px 18px; margin-bottom: 14px; }
.topico h3 { margin: 0 0 10px; color: var(--tinta); text-transform: none; letter-spacing: 0; font-size: 16px; display: flex; align-items: center; gap: 8px; }
.topico ul { margin: 0; padding-left: 20px; }
.topico li { margin-bottom: 6px; }
.topico .dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.topico-fortes { border-left-color: var(--s); }
.topico-fracos { border-left-color: var(--i); }
.topico-oport { border-left-color: var(--c); }
.topico-riscos { border-left-color: var(--d); }

.markdown h2 { font-size: 19px; margin-top: 22px; }

/* impressao / salvar em PDF: esconde botoes e barra de progresso */
@media print {
  .btn, .progresso { display: none !important; }
  body { background: #fff; }
  .card { box-shadow: none; border: 1px solid var(--linha); break-inside: avoid; }
}
.markdown ul { margin: 8px 0 12px 20px; }
.markdown li { margin-bottom: 4px; }
