:root {
  /* === BRANDBOOK MATRIX ENERGIA · DARK ===
     laranja + preto/grafite + branco. Variáveis mantêm o nome --raio*
     (herdado do funil base) mas carregam o LARANJA Matrix #F04B23. */
  --ink-900:        #070A0E;   /* preto/grafite Matrix (alinhado à arte do agente) */
  --ink-800:        #0B1014;
  --ink-700:        #121820;
  --ink-card:       #141A1E;
  --ink-card-hover: #1A2228;
  --ink-line:       rgba(255,255,255,0.09);
  --ink-line-soft:  rgba(255,255,255,0.05);
  --ink-line-mid:   rgba(255,255,255,0.16);

  --raio:           #F04B23;   /* laranja Matrix (principal) */
  --raio-soft:      #FF6A47;   /* laranja claro p/ texto/realce sobre dark */
  --raio-deep:      #C83A18;
  --raio-glow:      rgba(240,75,35,0.34);
  --raio-bg:        rgba(240,75,35,0.11);
  --raio-bg-soft:   rgba(240,75,35,0.05);
  --raio-border:    rgba(240,75,35,0.32);

  --steel:          #8A8F98;
  --steel-soft:     #B7BCC4;

  --white-pure:     #FFFFFF;
  --white-warm:     #F3F3F0;
  --white-soft:     rgba(243,243,240,0.80);
  --white-mute:     rgba(243,243,240,0.56);
  --white-faint:    rgba(243,243,240,0.40);

  --green-ok:       #2ECC71;
  --green-bg:       rgba(46,204,113,0.12);
  --green-border:   rgba(46,204,113,0.35);

  --sans: 'Poppins', -apple-system, system-ui, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-tap-highlight-color: transparent; scroll-behavior: smooth; }
em, i { font-style: normal; }

body {
  font-family: var(--sans);
  color: var(--white-warm);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  background:
    radial-gradient(ellipse 95% 42% at 50% -4%, rgba(168,52,28,0.17), transparent 62%),
    linear-gradient(180deg, var(--ink-900) 0%, #050709 100%);
  background-attachment: fixed;
}
/* === FUNDO GLOBAL PREMIUM · Matrix (brilho diagonal sutil, sem grid) ===
   o Matrix não usa grid blueprint — usa preto/grafite com leve specular highlight. */
body::before {
  content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 40% at 88% 8%, rgba(240,75,35,0.07), transparent 60%),
    radial-gradient(ellipse 70% 50% at 8% 96%, rgba(240,75,35,0.05), transparent 64%);
}

/* === PROGRESSIVE ENHANCEMENT · sistema de telas === */
.tela { display: block; }
.js-on .tela { display: none; }
.js-on .tela.ativa { display: block; }
.js-on .tela-hero.ativa,
.js-on .tela-processando.ativa { display: flex; }

/* === HEADER LOGO === */
.app-header { padding: 24px 22px 0; }
.app-header-inner {
  max-width: 1080px; margin: 0 auto;
  display: flex; align-items: center; justify-content: center;
}
.app-header .logo img { height: 38px; width: auto; display: block; }
@media (max-width: 720px) { .app-header .logo img { height: 30px; } }

/* === BARRA DE PROGRESSO === */
.progresso-wrap { max-width: 480px; margin: 20px auto 0; padding: 0 22px; }
/* trilha com nós numerados (check no concluído · glow no atual) */
.prog { position: relative; display: flex; justify-content: space-between; }
.prog-line { position: absolute; top: 14px; left: 26px; right: 26px; height: 3px;
  background: var(--ink-line-mid); border-radius: 99px; overflow: hidden; }
.prog-line-fill { height: 100%; width: 0%; background: var(--raio); border-radius: 99px;
  box-shadow: 0 0 8px var(--raio); transition: width .45s cubic-bezier(.4,0,.2,1); }
.prog-step { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 9px;
  flex: 0 0 auto; }
.prog-node { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--ink-line-mid);
  background: var(--ink-900); display: flex; align-items: center; justify-content: center;
  font-size: 12.5px; font-weight: 800; color: var(--white-mute); transition: all .25s; }
.prog-node svg { width: 15px; height: 15px; stroke: #fff; fill: none; stroke-width: 3;
  stroke-linecap: round; stroke-linejoin: round; display: none; }
.prog-label { font-size: 11px; letter-spacing: 1.3px; text-transform: uppercase; color: var(--white-mute); font-weight: 700; }
/* concluído = borda laranja + check */
.prog-step.done .prog-node { border-color: var(--raio); color: var(--raio); }
.prog-step.done .prog-num { display: none; }
.prog-step.done .prog-node svg { display: block; stroke: var(--raio); }
/* atual = preenchido laranja + glow */
.prog-step.active .prog-node { border-color: var(--raio); background: var(--raio); color: #fff;
  box-shadow: 0 0 0 4px var(--raio-bg), 0 0 16px -1px var(--raio); }
.prog-step.active .prog-label { color: var(--white-pure); }

/* === LAYOUT BASE DE TELA === */
.tela-inner {
  max-width: 720px; margin: 0 auto; padding: 40px 22px 80px;
}
.tela-quiz .tela-inner { padding-top: 34px; }

/* === TIPOGRAFIA === */
.eyebrow {
  font-size: 11.5px; font-weight: 700; letter-spacing: 2.6px; text-transform: uppercase;
  color: var(--raio); text-align: center; margin-bottom: 18px; display: block;
}
.eyebrow.neutra { color: var(--white-mute); }
.headline {
  font-size: clamp(28px, 5vw, 46px); font-weight: 600; line-height: 1.14;
  letter-spacing: -0.015em; color: var(--white-warm); text-align: center;
  margin: 0 auto 18px; max-width: 640px;
}
.headline strong { font-weight: 700; color: var(--raio); }
.headline.menor { font-size: clamp(29px, 8.5vw, 40px); font-weight: 800; }
.pergunta {
  font-size: clamp(30px, 9vw, 41px); font-weight: 700; line-height: 1.16;
  letter-spacing: -0.02em; text-align: center; margin: 0 auto 10px; max-width: 560px;
}
.pergunta strong { color: var(--raio); font-weight: 700; }
.sub {
  text-align: center; font-size: clamp(14px, 1.6vw, 16px); font-weight: 400;
  color: var(--white-soft); line-height: 1.6; max-width: 520px; margin: 0 auto 34px;
}
.sub-quiz { margin-bottom: 26px; }
.micro-hint {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  font-size: 12.5px; color: var(--white-mute); margin-top: 22px;
}
.micro-hint svg { width: 14px; height: 14px; stroke: var(--raio); fill: none; stroke-width: 2; }

/* === HERO === */
.tela-hero {
  flex-direction: column; min-height: calc(100vh - 64px);
}
.hero-body {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; text-align: center; padding: 30px 22px 60px;
  max-width: 760px; margin: 0 auto;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--raio-bg); border: 1px solid var(--raio-border);
  color: var(--raio-soft); font-size: 12px; font-weight: 600; letter-spacing: .4px;
  padding: 7px 15px; border-radius: 99px; margin-bottom: 26px;
}
.hero-badge svg { width: 14px; height: 14px; stroke: var(--raio); fill: none; stroke-width: 2; }
/* selo de autoridade Matrix (Hero) */
.selo-matrix { align-items: center; gap: 11px; padding: 9px 16px; }
.selo-matrix svg { width: 16px; height: 16px; flex-shrink: 0; }
.selo-matrix .sm-txt { display: flex; flex-direction: column; line-height: 1.22; text-align: left; }
.selo-matrix .sm-txt b { font-weight: 700; color: var(--raio-soft); font-size: 12.5px; letter-spacing: .2px; }
.selo-matrix .sm-txt i { font-size: 10.5px; color: var(--white-mute); font-weight: 500; }
/* atribuicao/disclaimer Matrix (credibilidade) */
.matrix-disclaimer { font-size: 13px; color: var(--white-soft); line-height: 1.55; background: var(--raio-bg); border: 1px solid var(--raio-border); border-radius: 13px; padding: 14px 16px; margin-bottom: 16px; }
.matrix-disclaimer strong { color: var(--raio-soft); font-weight: 700; }
.matrix-badges { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 13px; }
.matrix-badge { font-size: 11px; color: var(--white-soft); background: var(--ink-line-soft); border: 1px solid var(--ink-line); border-radius: 7px; padding: 5px 10px; line-height: 1.3; }
/* atribuicao curta sob o tripe do veredito */
.vt-attr { text-align: center; font-size: 12px; color: var(--white-mute); margin: 12px auto 0; max-width: 460px; }
.vt-attr strong { color: var(--white-soft); font-weight: 600; }
/* faixa de marcas que confiam na Matrix (credibilidade) */
.faixa-marcas { background: rgba(255,255,255,0.025); border: 1px solid var(--ink-line); border-radius: 16px; padding: 18px 16px; margin-bottom: 16px; text-align: center; }
.faixa-marcas .fm-titulo { font-size: 10.5px; letter-spacing: 1.4px; text-transform: uppercase; color: var(--white-mute); font-weight: 700; margin-bottom: 16px; }
.faixa-marcas .fm-logos { display: grid; grid-template-columns: repeat(4, 1fr); justify-items: center; align-items: center; gap: 7px; }
.faixa-marcas .fm-logos img { width: 100%; height: 50px; object-fit: contain; background: #fff; border-radius: 9px; padding: 11px 14px; box-sizing: border-box; }
@media (max-width: 560px) { .faixa-marcas .fm-logos { gap: 8px; } .faixa-marcas .fm-logos img { height: 44px; padding: 9px 11px; } }
/* [hidden] tem que vencer qualquer display de classe (ex: .momento flex, .campo block) */
[hidden] { display: none !important; }
/* momentos de autoridade/consciencia durante o quiz */
.momento { display: flex; align-items: flex-start; gap: 11px; max-width: 460px; margin: 16px auto 0; padding: 13px 15px; border-radius: 12px; font-size: 13px; line-height: 1.45; text-align: left; }
.momento .m-ico { flex-shrink: 0; font-size: 15px; line-height: 1.4; }
.momento.autoridade { background: var(--raio-bg); border: 1px solid var(--raio-border); color: var(--white-soft); }
.momento.autoridade strong { color: var(--raio-soft); font-weight: 700; }
/* consciência: card escuro · barra lateral laranja · ícone raio em círculo (refino 17/06) */
.momento.consciencia { background: rgba(255,255,255,0.025); border: 1px solid var(--ink-line);
  border-left: 3px solid var(--raio); border-radius: 14px; padding: 16px 18px; gap: 15px;
  align-items: center; font-size: 13.5px; color: var(--white-soft); }
.momento.consciencia strong { color: var(--white-warm); font-weight: 700; }
.momento.consciencia .m-ico { width: 52px; height: 52px; border-radius: 50%; border: 1px solid var(--ink-line-mid);
  display: flex; align-items: center; justify-content: center; font-size: 22px; line-height: 1; }
.momento.consciencia .m-ico svg { width: 25px; height: 25px; fill: var(--raio); }
.momento.solucao { background: var(--green-bg); border: 1px solid var(--green-border); color: var(--white-soft); }
.momento.solucao strong { color: var(--green-ok); font-weight: 700; }
.hero h1 {
  font-size: clamp(32px, 6.4vw, 58px); font-weight: 700; line-height: 1.08;
  letter-spacing: -0.022em; margin-bottom: 20px;
}
.hero h1 .hl { color: var(--raio); }
.hero-sub {
  font-size: clamp(15px, 2vw, 19px); color: var(--white-soft); line-height: 1.55;
  max-width: 540px; margin: 0 auto 16px;
}
.hero-puv {
  font-size: 13.5px; color: var(--white-mute); max-width: 500px; margin: 0 auto 36px;
}
.hero-puv strong { color: var(--white-soft); font-weight: 600; }
.tripe {
  display: flex; gap: 22px; justify-content: center; flex-wrap: wrap;
  margin-top: 34px; padding-top: 26px; border-top: 1px solid var(--ink-line-soft);
  width: 100%; max-width: 560px;
}
.tripe-item {
  display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--white-mute);
}
.tripe-item svg { width: 16px; height: 16px; stroke: var(--raio); fill: none; stroke-width: 2; }
/* bullets soco do Hero */
.hero-bullets { display: flex; flex-wrap: wrap; gap: 11px 24px; align-items: center; justify-content: center; margin: 8px auto 32px; max-width: 480px; }
.hero-bullets span { display: inline-flex; align-items: center; gap: 9px; font-size: 15.5px; color: var(--white-soft); }
.hero-bullets .b-full { flex-basis: 100%; justify-content: center; }
.hero-bullets span svg { width: 17px; height: 17px; stroke: var(--raio); fill: none; stroke-width: 2.2; flex-shrink: 0; }
.hero-bullets .b-selo { color: var(--white-warm); font-weight: 600; }
.hero-bullets .b-selo svg { fill: var(--raio-bg); }
/* claim + faixa de stats Matrix no Hero */
.hero-stats { display: flex; justify-content: center; align-items: stretch; margin: 30px auto 0; padding-top: 24px; border-top: 1px solid var(--ink-line-soft); width: 100%; max-width: 480px; }
.hero-stats .hs { flex: 1; text-align: center; padding: 0 10px; }
.hero-stats .hs + .hs { border-left: 1px solid var(--ink-line); }
.hero-stats .hs b { display: block; font-size: 23px; font-weight: 800; color: var(--raio); letter-spacing: -0.01em; }
.hero-stats .hs span { font-size: 10.5px; color: var(--white-mute); line-height: 1.35; display: block; margin-top: 5px; }

/* === BOTÕES === */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--sans); font-size: 16px; font-weight: 700; letter-spacing: .2px;
  padding: 18px 32px; border-radius: 13px; border: none; cursor: pointer;
  text-decoration: none; transition: transform .15s, box-shadow .25s, background .2s;
  width: 100%; max-width: 420px;
}
.btn-primario {
  background: linear-gradient(180deg, var(--raio-soft), var(--raio));
  color: #fff; box-shadow: 0 10px 32px -8px var(--raio-glow);
}
.btn-primario:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -8px var(--raio-glow); }
.btn-primario:disabled { background: linear-gradient(160deg, rgba(240,75,35,.08), rgba(240,75,35,.02));
  border: 1.5px solid var(--raio-border); color: var(--white-mute); box-shadow: none; opacity: 1;
  cursor: not-allowed; transform: none; }
.btn svg { width: 19px; height: 19px; stroke: currentColor; fill: none; stroke-width: 2.4; }
.btn-wrap { display: flex; flex-direction: column; align-items: center; gap: 14px; margin-top: 6px; }
.btn-zap { background: #25D366; color: #04210F; }
.btn-zap svg { fill: currentColor; stroke: none; }
/* botão de suporte secundário (ghost verde · não compete com o primário) */
.btn-wa-ghost { background: transparent; border: 1.5px solid #25D366; color: #25D366; box-shadow: none; }
.btn-wa-ghost svg { fill: currentColor; stroke: none; }
.btn-wa-ghost:hover { background: rgba(37,211,102,0.10); transform: none; box-shadow: none; }
/* aviso de valor mínimo na Q4 (neutro · vira alerta quando abaixo de R$300) */
/* nota R$300 = card com ícone (i) em círculo laranja (refino 17/06) */
.valor-hint { display: flex; align-items: center; gap: 14px; max-width: 460px; margin: 16px auto 0;
  background: rgba(255,255,255,.025); border: 1px solid var(--ink-line); border-radius: 14px;
  padding: 15px 18px; font-size: 13.5px; line-height: 1.45; color: var(--white-soft); text-align: left; transition: border-color .2s; }
.valor-hint svg { width: 30px; height: 30px; flex-shrink: 0; stroke: var(--raio); fill: none; stroke-width: 1.8; }
.valor-hint strong { color: var(--white-warm); font-weight: 700; }
.valor-hint.erro { border-color: var(--raio-border); color: var(--raio-soft); }
.valor-hint.erro strong { color: var(--raio); }
/* input de valor grande (destaque · arte do agente · ~108px de altura) */
.input-money-lg { border-color: var(--raio-border); border-radius: 18px; padding: 0 24px;
  background: linear-gradient(160deg, #0d1014, #060a0e); box-shadow: 0 0 30px -10px rgba(240,75,35,.25); }
.input-money-lg > span { font-size: 30px; margin-right: 14px; font-weight: 800; color: var(--white-mute); }
.input-money-lg input { padding: 34px 0; font-size: 34px; font-weight: 700; }
/* mapa "de onde vem o desconto" (timeline vertical · tela de credibilidade) */
.como-funciona { max-width: 460px; margin: 18px auto 22px; }
.cf-titulo { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--raio-soft); text-align: center; margin-bottom: 16px; }
.cf-fluxo { display: flex; flex-direction: column; }
.cf-passo { display: flex; align-items: flex-start; gap: 14px; position: relative; padding-bottom: 16px; }
.cf-passo:last-child { padding-bottom: 0; }
.cf-passo:not(:last-child)::before { content: ''; position: absolute; left: 21px; top: 46px; bottom: -2px; width: 2px; background: var(--ink-line); }
.cf-ico { flex-shrink: 0; width: 44px; height: 44px; border-radius: 12px; background: var(--raio-bg); border: 1px solid var(--raio-border); display: flex; align-items: center; justify-content: center; font-size: 21px; line-height: 1; }
.cf-txt { padding-top: 4px; }
.cf-txt h5 { font-size: 15px; font-weight: 700; color: var(--white-warm); margin: 0 0 3px; }
.cf-txt p { font-size: 13px; line-height: 1.45; color: var(--white-mute); margin: 0; }
/* faixa de cobertura (substitui o mapa de desconto por estado) */
.cobertura-band { max-width: 460px; margin: 6px auto 18px; padding: 20px 18px; border-radius: 14px; background: var(--raio-bg); border: 1px solid var(--raio-border); text-align: center; }
.cobertura-band .cb-icone svg { width: 24px; height: 24px; fill: var(--raio-soft); stroke: none; }
.cb-stats { display: flex; align-items: center; justify-content: center; gap: 20px; margin-top: 8px; }
.cb-stat { display: flex; flex-direction: column; }
.cb-stat strong { font-size: 30px; font-weight: 800; color: var(--raio-soft); line-height: 1; }
.cb-stat span { font-size: 12px; color: var(--white-mute); margin-top: 5px; }
.cb-sep { width: 1px; height: 36px; background: var(--ink-line); }
.cb-nota { font-size: 12.5px; color: var(--white-soft); margin: 13px auto 0; max-width: 330px; line-height: 1.45; }
.link-recusa {
  background: none; border: none; cursor: pointer; font-family: var(--sans);
  font-size: 13px; color: var(--white-faint); text-decoration: underline;
  text-underline-offset: 3px; padding: 4px;
}
.link-recusa:hover { color: var(--white-mute); }
.recusa-msg {
  display: none; font-size: 13px; color: var(--white-mute); text-align: center;
  max-width: 380px; margin: 4px auto 0; line-height: 1.5;
}
.recusa-msg.show { display: block; }

/* === OPÇÕES DE QUIZ === */
.opcoes { display: grid; gap: 12px; max-width: 460px; margin: 0 auto; }
.opcoes.duas { grid-template-columns: 1fr 1fr; }
.opcao {
  display: flex; align-items: center; gap: 14px; text-align: left;
  background: linear-gradient(168deg, var(--ink-card), var(--ink-800));
  border: 1.5px solid var(--ink-line);
  border-radius: 16px; padding: 17px 18px; cursor: pointer; position: relative; overflow: hidden;
  transition: border-color .18s, background .18s, transform .12s, box-shadow .2s;
  font-family: var(--sans); color: var(--white-warm); font-size: 15.5px; width: 100%;
}
.opcao:hover { border-color: var(--raio-border); background: var(--ink-card-hover); transform: translateY(-2px); box-shadow: 0 12px 30px -16px rgba(0,0,0,.8); }
.opcao.selecionada { border-color: var(--raio); background: var(--raio-bg); box-shadow: 0 0 0 1px var(--raio-border), 0 12px 34px -16px var(--raio-glow); }
.opcao-ico {
  flex-shrink: 0; width: 42px; height: 42px; border-radius: 11px;
  background: var(--raio-bg); display: flex; align-items: center; justify-content: center;
  font-size: 21px;
}
.opcao.duas-col { flex-direction: column; text-align: center; gap: 10px; padding: 22px 14px; }
.opcao.duas-col .opcao-ico { width: 52px; height: 52px; font-size: 26px; }
.opcao-texto { flex: 1; }
.opcao-titulo { display: block; font-weight: 600; line-height: 1.25; }
.opcao-desc { display: block; font-size: 12.5px; color: var(--white-mute); margin-top: 3px; line-height: 1.4; }

/* === Card de opção · PROPOSTA B (lista horizontal · ícone + radio) === */
.opcao-lista { gap: 16px; padding: 16px 18px; border-radius: 20px; }
.opcao-lista .opcao-ico { width: 58px; height: 58px; border-radius: 16px;
  background: linear-gradient(155deg, #FF6A47, #F04B23 58%, #D23E1A);
  box-shadow: 0 6px 16px -6px rgba(240,75,35,.6); }
.opcao-lista .opcao-ico svg { width: 28px; height: 28px; stroke: #fff; stroke-width: 2; fill: none; }
.opcao-lista .opcao-titulo { font-size: 17px; }
.opcao-lista:hover { transform: translateX(2px); }
.opcao-radio { flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--ink-line-mid); position: relative; transition: border-color .2s; }
.opcao.selecionada .opcao-radio { border-color: var(--raio); }
.opcao.selecionada .opcao-radio::after { content: ''; position: absolute; inset: 4px; border-radius: 50%; background: var(--raio); }

/* === CAMPOS DE FORM === */
.campo { max-width: 420px; margin: 0 auto 16px; }
.campo label {
  display: block; font-size: 12.5px; font-weight: 600; color: var(--white-soft);
  margin-bottom: 8px; letter-spacing: .2px;
}
.campo input, .campo select {
  width: 100%; font-family: var(--sans); font-size: 16px; color: var(--white-warm);
  background: var(--ink-card); border: 1.5px solid var(--ink-line);
  border-radius: 14px; padding: 18px 16px; transition: border-color .18s;
  appearance: none; -webkit-appearance: none;
}
/* campo de destaque (estado): borda laranja como na arte */
.campo select.sel-destaque { border-color: var(--raio-border); }
.campo select.sel-destaque:focus { border-color: var(--raio); }
.campo input::placeholder { color: var(--white-faint); }
.campo input:focus, .campo select:focus { outline: none; border-color: var(--raio); }
.campo select {
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23F04B23' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23F04B23' stroke-width='2.2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: left 16px center, right 14px center;
  padding-left: 48px; padding-right: 42px;
}
.campo select option { background: var(--ink-800); color: var(--white-warm); }
.campo-dupla { display: flex; gap: 12px; max-width: 420px; margin: 0 auto 16px; }
.campo-dupla .campo { margin-bottom: 0; }
.campo-dupla .campo.estado { flex: 0 0 120px; }
.campo-dupla .campo.cidade { flex: 1; }

/* combobox de cidade (busca filtrada por estado) */
.combo-wrap { position: relative; }
.combo-lista { position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 30; margin: 0; padding: 5px; list-style: none; max-height: 232px; overflow-y: auto; background: var(--ink-700); border: 1px solid var(--ink-line-mid); border-radius: 12px; box-shadow: 0 18px 44px -14px rgba(0,0,0,.75); }
.combo-lista[hidden] { display: none; }
.combo-lista li { padding: 11px 13px; font-size: 15px; color: var(--white-soft); cursor: pointer; border-radius: 8px; }
.combo-lista li:hover, .combo-lista li.ativo { background: var(--raio-bg); color: var(--white-warm); }
.combo-vazio { padding: 11px 13px; font-size: 13px; color: var(--white-mute); }

/* input de valor com prefixo R$ */
.input-money { display: flex; align-items: center; max-width: 420px; margin: 0 auto; background: var(--ink-card); border: 1.5px solid var(--ink-line); border-radius: 12px; padding: 0 16px; transition: border-color .18s; }
.input-money:focus-within { border-color: var(--raio); }
.input-money > span { font-size: 17px; color: var(--white-mute); font-weight: 700; margin-right: 9px; }
.input-money input { flex: 1; background: none; border: none; padding: 15px 0; font-size: 19px; font-weight: 600; color: var(--white-warm); font-family: var(--sans); }
.input-money input:focus { outline: none; }
.input-money input::placeholder { color: var(--white-faint); font-weight: 400; }
/* neutraliza o autofill do Chrome (fundo branco/azul) — mantém o campo dark */
input:-webkit-autofill, input:-webkit-autofill:hover, input:-webkit-autofill:focus,
select:-webkit-autofill {
  -webkit-text-fill-color: var(--white-warm) !important;
  -webkit-box-shadow: 0 0 0 1000px var(--ink-card) inset !important;
  caret-color: var(--white-warm);
  transition: background-color 99999s ease 0s;
}
.input-money input:-webkit-autofill { -webkit-box-shadow: 0 0 0 1000px var(--ink-card) inset !important; }

/* toggle titularidade */
.toggle-titular { max-width: 420px; margin: 6px auto 18px; }
.toggle-titular .toggle-pergunta { font-size: 13.5px; color: var(--white-soft); margin-bottom: 10px; font-weight: 500; }
.toggle-opcoes { display: flex; gap: 10px; }
.toggle-btn {
  flex: 1; font-family: var(--sans); font-size: 14px; font-weight: 600; cursor: pointer;
  background: var(--ink-card); border: 1.5px solid var(--ink-line); color: var(--white-soft);
  border-radius: 11px; padding: 13px; transition: all .16s;
}
.toggle-btn.on { border-color: var(--raio); background: var(--raio-bg); color: var(--raio-soft); }
.titular-nota {
  display: none; font-size: 12px; color: var(--white-mute); margin-top: 9px; line-height: 1.45;
  background: var(--ink-line-soft); border-radius: 9px; padding: 10px 12px;
}
.titular-nota.show { display: block; }

.lgpd { display: flex; align-items: flex-start; gap: 9px; max-width: 420px; margin: 4px auto 22px; }
.lgpd input { width: 17px; height: 17px; margin-top: 2px; accent-color: var(--raio); flex-shrink: 0; }
.lgpd label { font-size: 11.5px; color: var(--white-mute); line-height: 1.5; }

.btn-voltar {
  background: none; border: none; cursor: pointer; font-family: var(--sans);
  display: inline-flex; align-items: center; gap: 6px; color: var(--white-faint);
  font-size: 13px; margin: 24px auto 0; padding: 6px;
}
.btn-voltar:hover { color: var(--white-mute); }
.btn-voltar svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; }
.centro { display: flex; justify-content: center; }

/* === PROCESSAMENTO === */
.tela-processando { flex-direction: column; min-height: calc(100vh - 64px); justify-content: center; }
.proc-inner { max-width: 480px; margin: 0 auto; padding: 40px 26px; width: 100%; text-align: center; }
.proc-raio {
  width: 64px; height: 64px; margin: 0 auto 26px; border-radius: 18px;
  background: var(--raio-bg); border: 1px solid var(--raio-border);
  display: flex; align-items: center; justify-content: center; font-size: 32px;
  animation: pulseRaio 1.3s ease-in-out infinite;
}
@keyframes pulseRaio { 0%,100% { transform: scale(1); box-shadow: 0 0 0 0 var(--raio-glow); } 50% { transform: scale(1.06); box-shadow: 0 0 0 12px transparent; } }
.proc-titulo { font-size: 19px; font-weight: 600; margin-bottom: 28px; }
.proc-track { height: 6px; background: var(--ink-line); border-radius: 99px; overflow: hidden; margin-bottom: 26px; }
.proc-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--raio-deep), var(--raio)); border-radius: 99px; transition: width .5s ease; }
.proc-checks { list-style: none; text-align: left; display: flex; flex-direction: column; gap: 13px; }
.proc-check {
  display: flex; align-items: center; gap: 12px; font-size: 14.5px; color: var(--white-soft);
  opacity: 0; transform: translateY(6px); transition: opacity .35s, transform .35s;
}
.proc-check.appear { opacity: 1; transform: translateY(0); }
.proc-check.atual { color: var(--white-warm); font-weight: 500; }
.check-ico, .check-spin { width: 22px; height: 22px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.check-ico { background: var(--green-bg); border-radius: 50%; }
.check-ico svg { width: 13px; height: 13px; stroke: var(--green-ok); fill: none; stroke-width: 3; }
.check-spin { border: 2.5px solid var(--raio-bg); border-top-color: var(--raio); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* === VEREDITO === */
.veredito-eyebrow {
  display: flex; align-items: center; justify-content: center; gap: 9px; background: var(--green-bg);
  border: 1px solid var(--green-border); color: var(--green-ok); font-size: 12.5px;
  font-weight: 600; padding: 13px 18px; border-radius: 999px; margin: 0 auto 26px;
  width: 100%; max-width: 366px; line-height: 1.3;
}
/* CTA e demais blocos do veredito centralizados na mesma largura (~80%) */
.tela-veredito .btn-primario { max-width: 366px; padding: 25px 28px; border-radius: 20px; font-size: 17px; }
.tela-veredito .veredito-tripe, .tela-veredito .prova-geo { max-width: 366px; }
.veredito-eyebrow svg { width: 14px; height: 14px; stroke: var(--green-ok); fill: none; stroke-width: 2.5; flex-shrink: 0; }
.veredito-eyebrow .ve-txt { min-width: 0; }
.veredito-card {
  background: linear-gradient(165deg, var(--ink-card), var(--ink-700));
  border: 1.5px solid var(--raio-border); border-radius: 40px;
  padding: 44px 34px 34px; text-align: center; max-width: 366px; margin: 0 auto 22px;
  box-shadow: 0 24px 60px -24px rgba(0,0,0,.7);
}
/* eyebrow "Seu desconto" com traços laterais */
.veredito-label { font-size: 14px; font-weight: 600; color: var(--raio-soft); margin-bottom: 2px;
  display: flex; align-items: center; justify-content: center; gap: 13px; }
.veredito-label::before, .veredito-label::after { content: ''; width: 30px; height: 1px; background: var(--raio-border); }
.veredito-pct {
  font-size: clamp(108px, 33vw, 150px); font-weight: 800; line-height: .88;
  letter-spacing: -0.04em; color: #fff; margin-bottom: 4px;
}
.veredito-pct span { font-size: .46em; }
.veredito-pct-sub { font-size: 16px; color: var(--white-soft); margin-bottom: 22px; }
/* card economia: card único, 2 colunas com divisória vertical */
.economia-grid { display: flex; margin-bottom: 14px; background: rgba(255,255,255,.03);
  border: 1px solid var(--raio-bg-soft); border-radius: 24px; overflow: hidden; }
.economia-box { flex: 1; padding: 16px 8px; text-align: center; }
.economia-box + .economia-box { border-left: 1px solid var(--ink-line); }
.economia-box .aprox { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.6px; color: var(--raio-soft); margin-bottom: 3px; }
.economia-box .valor { font-size: clamp(26px, 7vw, 34px); font-weight: 800; color: #fff; letter-spacing: -0.02em; }
.economia-box .legenda { font-size: 10.5px; color: var(--raio-soft); margin-top: 4px; text-transform: uppercase; letter-spacing: 1.4px; font-weight: 700; }
/* equivalência: ícone play em círculo outline laranja + texto */
.equivalencia {
  background: rgba(255,255,255,.025); border: 1px solid var(--ink-line); border-radius: 24px;
  padding: 16px 18px; font-size: 15px; line-height: 1.45; color: var(--white-warm);
  display: flex; align-items: center; gap: 14px; text-align: left;
}
.equivalencia strong { color: var(--raio-soft); font-weight: 700; }
.equivalencia .ico { margin: 0; width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--raio-border);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.equivalencia .ico svg { width: 15px; height: 15px; fill: var(--raio); stroke: none; display: block; margin-left: 2px; }

/* === CLÍMAX: card ESCURO + borda laranja + glow externo + número néon (ref 17/06) === */
.veredito-card.solar {
  background:
    radial-gradient(ellipse 85% 55% at 50% 34%, rgba(240,75,35,.18), transparent 72%),
    linear-gradient(165deg, #16110E, #0a0807);
  border: 1.5px solid var(--raio); position: relative; overflow: hidden; color: #fff;
  box-shadow: 0 0 54px -4px rgba(240,75,35,.45), 0 0 0 1px rgba(240,75,35,.22),
    inset 0 0 70px -28px rgba(240,75,35,.40);
}
.veredito-card.solar .veredito-label { color: var(--raio-soft); }
/* número branco NÍTIDO com halo laranja ao redor (sem bloom branco que estoura) */
.veredito-card.solar .veredito-pct { color: #fff;
  text-shadow: 0 0 4px rgba(240,75,35,.45), 0 0 15px rgba(240,75,35,.5), 0 0 36px rgba(240,75,35,.38); }
.veredito-card.solar .veredito-pct-sub { color: rgba(255,255,255,.92); }
.veredito-card.solar .economia-box .valor { color: #fff; }
.veredito-tripe {
  display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin: 20px auto 0; max-width: 480px;
}
.vt-item {
  display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--white-mute);
  background: var(--ink-line-soft); border-radius: 99px; padding: 7px 13px;
}
.vt-item svg { width: 14px; height: 14px; stroke: var(--raio); fill: none; stroke-width: 2; }
.prova-geo {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  font-size: 13.5px; color: var(--white-soft); margin: 22px auto 0; max-width: 460px;
}
.prova-geo .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green-ok); box-shadow: 0 0 0 4px var(--green-bg); animation: blink 2s infinite; }
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: .4; } }
.prova-geo strong { color: var(--white-warm); font-weight: 700; }

/* === CREDIBILIDADE === */
.cred-bloco { max-width: 540px; margin: 0 auto; }
.video-frame {
  position: relative; aspect-ratio: 16/9; border-radius: 16px; overflow: hidden;
  background: linear-gradient(160deg, var(--ink-700), var(--ink-card));
  border: 1.5px solid var(--ink-line-mid); display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px; margin-bottom: 14px; cursor: pointer;
}
.video-play {
  width: 64px; height: 64px; border-radius: 50%; background: var(--raio);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 10px var(--raio-bg);
}
.video-play svg { width: 26px; height: 26px; fill: #fff; margin-left: 3px; }
.video-label { font-size: 13.5px; color: var(--white-soft); font-weight: 500; }
.gap-tag {
  position: absolute; top: 12px; left: 12px; font-size: 10px; letter-spacing: .5px;
  text-transform: uppercase; background: rgba(0,0,0,.55); color: var(--raio-soft);
  border: 1px solid var(--raio-border); border-radius: 6px; padding: 4px 8px;
}
/* === CARD MATRIX PREMIUM (laranja · cor real da marca · refino 16/06) === */
.matriz-card {
  --mz: #F04923; --mz-soft: #FF6A47; --mz-bg: rgba(240,73,35,.10); --mz-border: rgba(240,73,35,.30);
  position: relative; overflow: hidden; margin-bottom: 14px;
  background: linear-gradient(165deg, #1a1310, #110d0b);
  border: 1px solid var(--mz-border); border-radius: 20px; padding: 20px;
}
.matriz-card::before { content: ''; position: absolute; top: -40px; right: -40px; width: 190px; height: 190px;
  background: radial-gradient(circle, rgba(240,73,35,.22), transparent 70%); pointer-events: none; }
.mz-m { position: absolute; top: 16px; right: 16px; height: 76px; opacity: .92;
  filter: drop-shadow(0 6px 22px rgba(240,73,35,.55)); pointer-events: none; z-index: 0; }
.mz-head { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; margin-bottom: 14px; position: relative; z-index: 1; }
.mz-logo { height: 26px; width: auto; }
.mz-pill { display: inline-flex; align-items: center; gap: 7px; font-size: 9.5px; font-weight: 700;
  letter-spacing: .7px; text-transform: uppercase; color: var(--mz-soft);
  border: 1px solid var(--mz-border); border-radius: 99px; padding: 5px 11px; }
.mz-pill .mz-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mz); box-shadow: 0 0 8px var(--mz); }
.mz-title { font-size: clamp(19px, 5.2vw, 24px); font-weight: 800; line-height: 1.13; letter-spacing: -.02em;
  color: var(--white-warm); max-width: 74%; margin-bottom: 10px; position: relative; z-index: 1; }
.mz-title span { color: var(--mz-soft); }
.mz-desc { font-size: 12.5px; color: var(--white-mute); line-height: 1.5; margin-bottom: 16px; position: relative; z-index: 1; }
.mz-desc span { color: var(--mz-soft); font-weight: 600; }
.mz-stats { display: flex; gap: 8px; background: rgba(255,255,255,.02); border: 1px solid var(--ink-line);
  border-radius: 14px; padding: 13px 11px; margin-bottom: 13px; position: relative; z-index: 1; }
.mz-stat { flex: 1; display: flex; align-items: center; gap: 9px; min-width: 0; }
.mz-sico { width: 34px; height: 34px; border-radius: 50%; background: var(--mz-bg); border: 1px solid var(--mz-border);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mz-sico svg { width: 17px; height: 17px; stroke: var(--mz-soft); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.mz-st { min-width: 0; }
.mz-st strong { display: block; font-size: 15px; font-weight: 800; color: var(--mz-soft); line-height: 1; letter-spacing: -.02em; }
.mz-st span { font-size: 10px; color: var(--white-mute); }
.mz-badges { display: flex; flex-wrap: wrap; gap: 8px; position: relative; z-index: 1; }
.mz-badge { display: inline-flex; align-items: center; gap: 7px; font-size: 11.5px; color: var(--white-soft);
  background: rgba(255,255,255,.02); border: 1px solid var(--ink-line); border-radius: 11px; padding: 8px 12px; }
.mz-badge svg { width: 14px; height: 14px; stroke: var(--mz-soft); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
@media (min-width: 560px) { .mz-title { max-width: 70%; } }
.prova-img {
  width: 100%; border-radius: 14px; border: 1px solid var(--ink-line); margin-bottom: 14px; display: block;
}
.cred-selos { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; margin-bottom: 8px; }
.cred-selo {
  display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--white-soft);
  background: var(--ink-line-soft); border-radius: 99px; padding: 8px 14px;
}
.cred-selo svg { width: 14px; height: 14px; stroke: var(--raio); fill: none; stroke-width: 2; }

/* === COUNTDOWN WHATSAPP (V2) === */
.wa-count-wrap { margin: 30px auto 26px; }
.wa-count {
  width: 92px; height: 92px; margin: 0 auto 12px; border-radius: 50%;
  background: var(--green-bg); border: 2px solid var(--green-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 44px; font-weight: 800; color: var(--green-ok); line-height: 1;
}
.wa-count-label { font-size: 13px; color: var(--white-mute); }

/* === TUTORIAL === */
.tut-passos { display: flex; flex-direction: column; gap: 14px; max-width: 480px; margin: 0 auto 30px; }
.tut-passo {
  display: flex; gap: 16px; align-items: center; background: var(--ink-card);
  border: 1.5px solid var(--ink-line); border-radius: 14px; padding: 16px 18px;
}
.tut-num {
  flex-shrink: 0; width: 38px; height: 38px; border-radius: 10px;
  background: var(--raio); color: #fff; font-weight: 800; font-size: 17px;
  display: flex; align-items: center; justify-content: center;
}
.tut-texto h4 { font-size: 15px; font-weight: 600; margin-bottom: 2px; }
.tut-texto p { font-size: 13px; color: var(--white-mute); line-height: 1.45; }
.caminhos-divisor {
  text-align: center; font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--white-faint); margin: 4px auto 16px; max-width: 360px;
  display: flex; align-items: center; gap: 12px;
}
.caminhos-divisor::before, .caminhos-divisor::after { content: ''; flex: 1; height: 1px; background: var(--ink-line); }

/* === TOAST FOMO === */
.toast {
  position: fixed; left: 16px; bottom: 16px; z-index: 60; max-width: 320px;
  display: flex; align-items: center; gap: 11px; background: var(--ink-700);
  border: 1px solid var(--ink-line-mid); border-radius: 13px; padding: 12px 15px;
  box-shadow: 0 16px 40px -12px rgba(0,0,0,.7);
  opacity: 0; transform: translateY(16px); transition: opacity .4s, transform .4s; pointer-events: none;
}
.toast.show { opacity: 1; transform: translateY(0); }
.toast-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--green-ok); box-shadow: 0 0 0 4px var(--green-bg); flex-shrink: 0; }
.toast-texto { font-size: 12.5px; color: var(--white-soft); line-height: 1.35; }
.toast-texto strong { color: var(--white-warm); font-weight: 600; }

/* === EXCEÇÕES === */
.aviso-ico {
  width: 60px; height: 60px; margin: 0 auto 22px; border-radius: 16px;
  background: var(--ink-line-soft); border: 1px solid var(--ink-line-mid);
  display: flex; align-items: center; justify-content: center; font-size: 30px;
}

/* === RODAPÉ === */
.rodape {
  text-align: center; font-size: 11px; color: var(--white-faint); line-height: 1.6;
  padding: 30px 22px 40px; max-width: 600px; margin: 0 auto;
}
.rodape a { color: var(--white-mute); }

/* === MOBILE === */
@media (max-width: 560px) {
  .opcoes.duas { grid-template-columns: 1fr; }
  .economia-grid { gap: 8px; }
  .btn { font-size: 15px; padding: 17px 22px; }
  .veredito-card { padding: 26px 18px; }
  .matriz-card { flex-direction: column; }
  .tripe { gap: 14px; }
}

/* === Nota miúda do filtro de estado (só PF · estado não autorizado) === */
.estado-miudo {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--white-mute);
  margin: 10px 2px 0;
  text-align: left;
}

/* === Player de vídeo real (substitui o placeholder na credibilidade) === */
.video-frame.video-real { cursor: default; gap: 0; }
.video-frame.video-real video {
  width: 100%; height: 100%; object-fit: cover; display: block; background: #000;
}
.video-label { display: block; text-align: center; margin: 0 0 18px; }

/* ===================================================================
   HERO IMAGEM · arte do agente (100% fiel) + só o botão vivo
   =================================================================== */
.js-on .tela-hero.hero-img { display: none; }
.js-on .tela-hero.hero-img.ativa { display: block; }
body:has(.tela-hero.hero-img.ativa) .app-header { display: none; }
.hero-shot { position: relative; width: 100%; max-width: 480px; margin: 0 auto; line-height: 0; }
.hero-shot img { width: 100%; display: block; }
.hero-shot-cta { position: absolute; left: 9.7%; top: 77.7%; width: 80.5%; height: 6.7%;
  background: transparent; border: none; padding: 0; cursor: pointer; border-radius: 11px;
  -webkit-tap-highlight-color: transparent; transition: transform .1s ease; }
/* "acende" no hover/toque: clareia + glow laranja + leve press */
.hero-shot-cta::after { content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  opacity:0; transition: opacity .14s ease;
  background: linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.04));
  box-shadow: 0 0 42px 6px rgba(240,75,35,.62); }
.hero-shot-cta:hover::after { opacity:.85; }
.hero-shot-cta:active { transform: scale(.985); }
.hero-shot-cta:active::after { opacity:1; background: linear-gradient(180deg, rgba(255,255,255,.32), rgba(255,255,255,.11)); }
.hero-shot-cta:focus-visible { outline: 2px solid #fff; outline-offset: 3px; }

/* ===================================================================
   TELAS-IMAGEM (shot) · arte do agente 100% + só os elementos vivos
   imagem de fundo + hotspots transparentes (seleção/CTA) por cima
   =================================================================== */
.tela.shot-q .shot-wrap { position: relative; width: 100%; max-width: 480px; margin: 0 auto; line-height: 0; }
.tela.shot-q .shot-wrap > img { width: 100%; display: block; }
/* esconde header + progresso globais (a imagem já traz logo e barra) */
body:has(.tela.shot-q.ativa) .app-header,
body:has(.tela.shot-q.ativa) #progresso { display: none !important; }
.tela.shot-q .opcoes { position: static; display: block; max-width: none; margin: 0; }
/* hotspot de opção (card) · transparente de verdade (vence o visual do .opcao) */
.tela.shot-q .shot-opt,
.tela.shot-q .shot-opt:hover,
.tela.shot-q .shot-opt.selecionada {
  position: absolute; background: transparent; border: none; transform: none;
  padding: 0; cursor: pointer; border-radius: 20px; -webkit-tap-highlight-color: transparent;
  transition: box-shadow .15s; }
.tela.shot-q .shot-opt.selecionada {
  box-shadow: inset 0 0 0 2.5px var(--raio), 0 0 28px -6px var(--raio-glow); }
/* radio-overlay: círculo laranja que COBRE o anel da arte (vira radio cheio) · aparece na seleção */
.tela.shot-q .shot-radio { position: absolute; width: 30px; height: 30px; border-radius: 50%;
  background: var(--raio); border: 2px solid #fff2; box-shadow: 0 0 0 3px var(--ink-900);
  transform: translate(-50%,-50%) scale(0); transition: transform .18s ease;
  pointer-events: none; z-index: 3; }
.tela.shot-q .shot-radio::after { content:''; position:absolute; inset:7px; border-radius:50%; background:#fff; }
.tela.shot-q .opcoes:has(.shot-opt[data-valor="pf"].selecionada) ~ .shot-radio.r-pf,
.tela.shot-q .opcoes:has(.shot-opt[data-valor="pj"].selecionada) ~ .shot-radio.r-pj {
  transform: translate(-50%,-50%) scale(1); }
/* Q2 · select de estado transparente sobre a arte + valor sobreposto */
.tela.shot-q .shot-field { position: absolute; }
.tela.shot-q .shot-select { width: 100%; height: 100%; opacity: 0; cursor: pointer; border: none;
  background: transparent; font-family: var(--sans); font-size: 16px; -webkit-appearance: none; appearance: none; }
.tela.shot-q .shot-field-val { position: absolute; top: 6%; bottom: 6%; left: 12.7%; right: 13%;
  display: none; align-items: center; padding: 0 2px; pointer-events: none;
  background: #0B1016; color: #fff; font-weight: 500; font-size: clamp(15px,4.6vw,20px); white-space: nowrap; overflow: hidden; }
.tela.shot-q .shot-field-val.show { display: flex; }
/* distribuidora: overlay que aparece (cobre o momento) quando o estado é escolhido */
.tela.shot-q .shot-distrib { position: absolute; left: 7%; width: 86%; top: 63.2%; z-index: 4;
  background: var(--ink-900); border: 1px solid var(--raio-border); border-radius: 14px; padding: 12px 14px;
  box-shadow: 0 14px 34px -16px rgba(0,0,0,.7); }
.tela.shot-q .shot-distrib label { display: block; font-size: 11.5px; color: var(--white-soft); margin-bottom: 7px; font-weight: 600; }
.tela.shot-q .shot-distrib select { width: 100%; background: #0B1016; color: #fff; border: 1.5px solid var(--raio-border);
  border-radius: 10px; padding: 13px 40px 13px 14px; font-family: var(--sans); font-size: 15px; appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23F04B23' stroke-width='2.2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; }
.tela.shot-q .shot-semcob { position: absolute; left: 7%; width: 86%; top: 63.2%; z-index: 4; margin: 0;
  background: var(--ink-900); box-shadow: 0 14px 34px -16px rgba(0,0,0,.7); }
/* botão Continuar: aparece aceso (laranja) quando habilita; some no disabled (mostra o botão translúcido da arte) */
.shot-cont { position: absolute; display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--raio); color: #fff; border: none; border-radius: 16px; cursor: pointer;
  font-family: var(--sans); font-weight: 700; font-size: clamp(15px,4.4vw,18px); letter-spacing: .2px;
  opacity: 0; pointer-events: none; transition: opacity .22s, transform .1s;
  box-shadow: 0 0 36px -6px rgba(240,75,35,.6); }
.shot-cont:not([disabled]) { opacity: 1; pointer-events: auto; }
.shot-cont:not([disabled]):active { transform: scale(.985); }
.shot-cont svg { width: 18px; height: 18px; stroke: #fff; fill: none; stroke-width: 2.6; }

/* ===================================================================
   HERO MATRIX · refino do agente (17/06)
   foto sangrando + logo sobre a foto + card do número (borda laranja)
   + onda com linha laranja + chips outline círculo + CTA glow + stats com ícones
   =================================================================== */
.tela-hero.is-rich { min-height: 0; padding-bottom: 30px; }
.js-on .tela-hero.is-rich { display: none; }
.js-on .tela-hero.is-rich.ativa { display: block; }
/* no hero o logo vai SOBRE a foto → esconde o header global */
body:has(.tela-hero.is-rich.ativa) .app-header { display: none; }

/* imagem-herói: glow laranja, fade dark na base · proporção compacta (encaixa no mobile) */
.hr-media { position: relative; width: 100%; aspect-ratio: 4 / 4.1; overflow: hidden; background: #000; }
.hr-media > img { width: 100%; height: 100%; object-fit: cover; object-position: center 26%; display: block;
  filter: hue-rotate(-20deg) saturate(1.1) contrast(1.04); }
.hr-media::after { content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(11,16,18,.22) 0%, transparent 28%, transparent 60%, var(--ink-900) 99%); }

/* logo sobre a foto (topo-esquerda) */
.hr-logo { position:absolute; top:22px; left:22px; z-index:7; display:block; }
.hr-logo img { height:30px; width:auto; display:block; }

/* card do número-herói (preto · borda laranja · brilho no topo) */
.hr-bignum-card { position:absolute; z-index:5; right:20px; bottom:16%; text-align:left;
  background: linear-gradient(158deg, rgba(24,16,14,.86), rgba(9,7,7,.95));
  -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px);
  border:1px solid var(--raio-border); border-radius:22px; padding:18px 26px 20px;
  box-shadow: 0 24px 50px -18px rgba(0,0,0,.78), inset 0 1px 0 rgba(255,106,71,.35); overflow:hidden; }
.hr-bignum-card::before { content:''; position:absolute; top:-2px; right:-2px; width:110px; height:54px;
  background: radial-gradient(circle at 92% 0%, rgba(255,106,71,.75), transparent 60%); pointer-events:none; }
.hr-bignum-card i { display:block; font-style:normal; font-size:19px; font-weight:600; color: var(--white-soft); margin-bottom:-4px; }
.hr-bignum-card b { display:block; font-size: clamp(60px, 18vw, 76px); font-weight:800; color: var(--raio);
  line-height:1; letter-spacing:-.02em; }
.hr-bignum-card span { display:block; font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  color: var(--white-warm); margin-top:9px; line-height:1.4; }

/* onda com linha laranja */
.hr-wave { position:relative; margin-top:-1px; line-height:0; background:var(--ink-900); }
.hr-wave svg { display:block; width:100%; height:48px; }

/* conteúdo do hero */
.hr-card { position:relative; z-index:6; margin:0; padding:8px 24px 8px; text-align:left;
  background:transparent; border:none; border-radius:0; box-shadow:none; }
.hr-card h1 { font-size: clamp(30px, 8.6vw, 40px); line-height:1.07; font-weight:800; letter-spacing:-.02em; margin:0; color: var(--white-pure); }
.hr-card h1 .hl { color: var(--raio); }
.hr-sub { margin-top:14px; font-size:15.5px; line-height:1.5; color: var(--white-soft); }
.hr-sub strong { color: var(--white-warm); font-weight:700; }

/* chips: outline + ícone círculo laranja */
.hr-chips { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-top:22px; }
.hr-chip { display:inline-flex; align-items:center; gap:9px; background: rgba(255,255,255,.025);
  border:1px solid var(--ink-line-mid); border-radius:99px; padding:11px 18px; font-size:14.5px; color: var(--white-warm); font-weight:600; }
.hr-chip .ci { width:22px; height:22px; border-radius:50%; border:1.5px solid var(--raio); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.hr-chip .ci svg { width:12px; height:12px; stroke: var(--raio); fill:none; stroke-width:2.6; }
.hr-card .btn-wrap { margin-top:24px; }

/* CTA com glow laranja */
.hr-cta { width:100%; max-width:none; background: var(--raio); color:#fff; border-radius:15px; padding:20px 24px;
  font-size:17px; font-weight:700; box-shadow: 0 0 40px -6px rgba(240,75,35,.62), 0 14px 30px -12px rgba(240,75,35,.5); }
.hr-cta:hover { transform: translateY(-2px); box-shadow: 0 0 52px -4px rgba(240,75,35,.78), 0 18px 36px -12px rgba(240,75,35,.55); }
.hr-cta svg { width:18px; height:18px; stroke:#fff; fill:none; stroke-width:2.6; }

/* stats com ícones */
.hr-stats { display:flex; margin:28px 0 0; border:1px solid var(--ink-line); border-radius:18px; background: rgba(255,255,255,.02); overflow:hidden; }
.hr-stat { flex:1; text-align:center; padding:18px 8px; }
.hr-stat + .hr-stat { border-left:1px solid var(--ink-line); }
.hr-stat-ico { display:block; width:26px; height:26px; margin:0 auto 8px; }
.hr-stat-ico svg { width:26px; height:26px; stroke: var(--raio); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.hr-stat b { display:block; font-size:21px; font-weight:800; color: var(--raio); letter-spacing:-.02em; white-space:nowrap; }
.hr-stat span { display:block; font-size:10px; color: var(--white-mute); line-height:1.3; margin-top:6px; }

/* ===================================================================
   DESKTOP · funil vira COLUNA CENTRAL tipo app (não estica) · refino 15/06
   o quiz é mobile-first; no desktop centraliza num "device" de ~480px,
   fundo dark/grid preenche as laterais.
   =================================================================== */
@media (min-width: 600px) {
  .app-header-inner { max-width: 480px; }
  .progresso-wrap { max-width: 480px; }
  /* cada tela = coluna central de 480 */
  .tela { max-width: 480px; margin-left: auto; margin-right: auto; }
  .tela-hero { min-height: 0; }
  .tela-inner { max-width: 480px; }
  /* hero rich mantém a proporção retrato (NUNCA 16/9 esticado) */
  .hr-media { aspect-ratio: 4 / 4.2; }
  .hr-card, .hr-stats { max-width: none; }
  /* telas claras: painel central, não full-bleed esticado */
  .tela.light { min-height: 0; padding-top: 14px; padding-bottom: 40px; border-radius: 20px; margin-top: 14px; margin-bottom: 14px; }
  /* processando central */
  .tela-processando { min-height: 60vh; }
}

/* ===================================================================
   MODO LIGHT · telas claras do fluxo · PADRÃO SOLARIS (refino 15/06 v2)
   Princípio: fundo off-white + grid + CARDS PRETOS (não brancos) +
   reforço amarelo. O contraste card-preto-sobre-claro é o que dá qualidade.
   Ref: DESIGN-SYSTEM-SOLARIS.json
   =================================================================== */
.tela.light { background: #F1F1EE; color: #16140D; min-height: 100vh; position: relative; z-index: 1; }
/* grid técnico próprio (linhas escuras sobre o off-white) */
.tela.light::before {
  content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(20,18,10,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20,18,10,.05) 1px, transparent 1px);
  background-size: 40px 40px;
  -webkit-mask-image: radial-gradient(ellipse 120% 70% at 50% 22%, #000 52%, transparent 92%);
          mask-image: radial-gradient(ellipse 120% 70% at 50% 22%, #000 52%, transparent 92%);
}
.tela.light .tela-inner { position: relative; z-index: 1; }
.tela.light .eyebrow { color: var(--raio-deep); }
.tela.light .eyebrow.neutra { color: rgba(20,18,10,.45); }
.tela.light .pergunta, .tela.light .headline { color: #16140D; }
.tela.light .pergunta strong, .tela.light .headline strong { color: var(--raio-deep); }
.tela.light .sub { color: rgba(20,18,10,.6); }
.tela.light .micro-hint { color: rgba(20,18,10,.5); }
.tela.light .micro-hint svg { stroke: var(--raio-deep); }

/* opções = CARDS PRETOS arredondados sobre o claro (assinatura Solaris) */
.tela.light .opcao {
  background: linear-gradient(165deg, #16161A, #0E0E10); border-color: rgba(0,0,0,.4); color: #F4F4F2;
  box-shadow: 0 14px 30px -16px rgba(20,18,10,.4);
}
.tela.light .opcao:hover { background: linear-gradient(165deg, #1A1A20, #101013); border-color: var(--raio); transform: translateY(-3px); box-shadow: 0 18px 36px -16px rgba(20,18,10,.5); }
.tela.light .opcao.selecionada { background: linear-gradient(165deg, #1d1a10, #141008); border-color: var(--raio); box-shadow: 0 0 0 1px var(--raio), 0 14px 34px -16px var(--raio-glow); }
.tela.light .opcao-ico { background: var(--raio); }
.tela.light .opcao-titulo { color: #F4F4F2; }
.tela.light .opcao-desc { color: rgba(244,244,242,.5); }

/* inputs / selects: brancos com borda (legíveis no off-white) */
.tela.light .campo input, .tela.light .campo select, .tela.light input, .tela.light textarea {
  background-color: #FFFFFF; border-color: rgba(20,18,10,.16); color: #16140D;
}
.tela.light input::placeholder, .tela.light textarea::placeholder { color: rgba(20,18,10,.4); }
.tela.light .campo label, .tela.light label, .tela.light .campo-label { color: rgba(20,18,10,.7); }
.tela.light .campo select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23C83A18' stroke-width='2.2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center;
}
.tela.light .campo select option { background: #FFFFFF; color: #16140D; }

/* toggle Sim/Não: branco→amarelo cheio quando ativo */
.tela.light .toggle-pergunta { color: rgba(20,18,10,.7); }
.tela.light .toggle-btn { background: #FFFFFF; border-color: rgba(20,18,10,.16); color: rgba(20,18,10,.7); }
.tela.light .toggle-btn.on { background: var(--raio); border-color: transparent; color: #fff; font-weight: 800; }
.tela.light .titular-nota { color: rgba(20,18,10,.62); background: rgba(20,18,10,.05); }

/* momentos: reforço = bloco amarelo cheio (Solaris) · neutro = card claro */
.tela.light .momento.consciencia { background: #FFFFFF; border-color: rgba(20,18,10,.1); color: rgba(20,18,10,.7); }
.tela.light .momento.consciencia strong { color: #16140D; }
.tela.light .momento.autoridade { background: var(--raio); border-color: transparent; color: #fff; }
.tela.light .momento.autoridade strong { color: #fff; }
.tela.light .momento.solucao { background: #E9F6EF; border-color: rgba(20,120,80,.2); color: #14603F; }
.tela.light .momento.solucao strong { color: #0E7A4B; }
.tela.light .valor-hint { color: rgba(20,18,10,.6); }
.tela.light .valor-hint svg { stroke: var(--raio-deep); }
.tela.light .valor-hint strong { color: var(--raio-deep); }
.tela.light .estado-miudo { color: rgba(20,18,10,.5); }

/* input de valor (R$) no claro */
.tela.light .input-money { background: #FFFFFF; border-color: rgba(20,18,10,.16); }
.tela.light .input-money > span { color: rgba(20,18,10,.55); }
.tela.light .input-money input { background-color: transparent; color: #16140D; }
.tela.light .input-money input::placeholder { color: rgba(20,18,10,.35); }

/* faixa de marcas no claro: card branco definido + chips com borda */
.tela.light .faixa-marcas { background: #FFFFFF; border-color: rgba(20,18,10,.1); box-shadow: 0 6px 20px -14px rgba(20,18,10,.3); }
.tela.light .faixa-marcas .fm-titulo { color: rgba(20,18,10,.5); }
.tela.light .faixa-marcas .fm-logos img { border: 1px solid rgba(20,18,10,.09); }

/* voltar / links neutros no claro */
.tela.light .btn-voltar, .tela.light .link-recusa { color: rgba(20,18,10,.5); }
.tela.light .btn-voltar svg { stroke: rgba(20,18,10,.5); }

/* ===================================================================
   "COMO O DESCONTO ACONTECE" · cards numerados + chips (refino 16/06)
   redesign da seção como-funciona da credibilidade · ref infográfico
   =================================================================== */
.cf2 { margin: 10px 0 18px; }
.cf2-eyebrow { display: flex; align-items: center; justify-content: center; gap: 10px;
  text-align: center; font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--raio); font-weight: 800; margin-bottom: 12px; }
.cf2-eyebrow::before, .cf2-eyebrow::after { content: ''; width: 22px; height: 1px; background: var(--raio-border); }
.cf2-headline { text-align: center; font-size: clamp(23px, 6.6vw, 30px); font-weight: 800; line-height: 1.08; letter-spacing: -.02em; color: var(--white-warm); margin-bottom: 20px; }
.cf2-headline span { color: var(--raio); }
.cf2-sub { text-align: center; font-size: 13px; color: var(--white-mute); margin: 9px auto 20px; line-height: 1.5; max-width: 340px; }

.cf2-steps { display: flex; flex-direction: column; gap: 12px; position: relative; padding-left: 28px; }
/* timeline · linha + dots com glow (ref) */
.cf2-steps::before { content: ''; position: absolute; left: 6px; top: 34px; bottom: 34px; width: 2px; background: var(--raio-border); }
.cf2-step { position: relative; display: flex; align-items: center; gap: 13px;
  background: linear-gradient(165deg, var(--ink-card), var(--ink-800)); border: 1px solid var(--ink-line);
  border-radius: 18px; padding: 16px 16px 16px 14px; }
.cf2-step::before { content: ''; position: absolute; left: -28px; top: 50%; transform: translateY(-50%);
  width: 13px; height: 13px; border-radius: 50%; background: var(--raio);
  box-shadow: 0 0 12px var(--raio), 0 0 0 4px rgba(255,220,0,.12); }
.cf2-step::after { content: ''; position: absolute; left: -15px; top: 50%; width: 15px; height: 2px; background: var(--raio-border); }
.cf2-num { flex-shrink: 0; font-size: 22px; font-weight: 800; color: var(--raio); letter-spacing: -.03em; line-height: 1; min-width: 26px; text-align: center; font-variant-numeric: tabular-nums; }
.cf2-ico { width: 50px; height: 50px; border-radius: 14px; background: var(--raio-bg); border: 1px solid var(--raio-border);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cf2-ico svg { width: 26px; height: 26px; stroke: var(--raio); fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.cf2-body { flex: 1; min-width: 0; }
.cf2-body h4 { font-size: 15.5px; font-weight: 700; line-height: 1.2; margin-bottom: 5px; color: var(--white-warm); }
.cf2-body > p { font-size: 12.5px; color: var(--white-mute); line-height: 1.45; margin-bottom: 11px; }
.cf2-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.cf2-chip { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 600;
  color: var(--raio-soft); background: var(--raio-bg); border: 1px solid var(--raio-border); border-radius: 99px; padding: 5px 11px; }
.cf2-chip svg { width: 11px; height: 11px; stroke: var(--raio); fill: none; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }

.cf2-footer { margin-top: 14px; background: linear-gradient(165deg, var(--ink-card), var(--ink-800)); border: 1px solid var(--ink-line);
  border-radius: 16px; padding: 16px 18px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; justify-content: center; }
.cf2-footer img { height: 26px; width: auto; }
.cf2-fstat { display: flex; flex-direction: column; line-height: 1.2; padding-left: 14px; border-left: 1px solid var(--ink-line); }
.cf2-fstat strong { font-size: 14px; font-weight: 800; color: var(--raio); }
.cf2-fstat span { font-size: 11px; color: var(--white-mute); }

/* ===================================================================
   PÁGINA DE ATIVAÇÃO · infográfico (ref do operador · 16/06)
   card "você vai precisar" + headline + timeline 4 passos + CTA + rodapé
   =================================================================== */
.tela-tutorial .tela-inner { max-width: 480px; }
/* card: você vai precisar */
.at-precisa { position: relative; overflow: hidden; display: flex; align-items: center; gap: 14px;
  background: linear-gradient(165deg, var(--ink-card), var(--ink-800)); border: 1px solid var(--raio-border);
  border-radius: 18px; padding: 16px 18px; margin-bottom: 22px; }
.at-precisa::before { content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(ellipse 55% 120% at 90% 50%, var(--raio-bg), transparent 68%); }
.at-precisa-ico { width: 54px; height: 54px; border-radius: 50%; background: var(--raio-bg); border: 1px solid var(--raio-border);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; position: relative; z-index: 1; }
.at-precisa-ico svg { width: 25px; height: 25px; stroke: var(--raio); fill: none; stroke-width: 1.7; stroke-linecap:round; stroke-linejoin:round; }
.at-precisa-txt { position: relative; z-index: 1; }
.at-badge { display: inline-block; font-size: 10px; font-weight: 800; letter-spacing: 1.3px; text-transform: uppercase;
  color: var(--raio); border: 1px solid var(--raio-border); border-radius: 99px; padding: 4px 10px; margin-bottom: 8px; }
.at-precisa-txt p { font-size: 14px; line-height: 1.4; color: var(--white-soft); }
.at-precisa-txt strong { color: var(--white-warm); font-weight: 700; }
.at-deco-bolt { position: absolute; right: -4px; top: 50%; transform: translateY(-50%); width: 88px; height: 88px;
  fill: var(--raio); opacity: .13; filter: drop-shadow(0 0 16px rgba(255,220,0,.5)); pointer-events: none; }
/* headline */
.at-headline { font-size: clamp(20px, 5.4vw, 25px); font-weight: 800; line-height: 1.2;
  letter-spacing: -.02em; margin-bottom: 20px; color: var(--white-warm); }
.at-headline span { color: var(--raio); }
.at-h-bolt { display: inline-block; vertical-align: -4px; width: 24px; height: 24px; margin-right: 7px; fill: var(--raio); }
/* timeline */
.at-steps { display: flex; flex-direction: column; gap: 12px; position: relative; padding-left: 50px; }
.at-steps::before { content:''; position:absolute; left: 21px; top: 24px; bottom: 24px; width: 2px; background: var(--raio-border); }
.at-step { position: relative; }
.at-node { position: absolute; left: -50px; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%;
  background: var(--raio); color: #fff; font-size: 18px; font-weight: 800; display:flex; align-items:center; justify-content:center;
  box-shadow: 0 0 0 4px var(--ink-900), 0 0 16px rgba(255,220,0,.55); z-index: 1; }
.at-node-check svg { width: 22px; height: 22px; stroke: #fff; fill: none; stroke-width: 3; }
.at-card { display: flex; align-items: center; gap: 14px; background: linear-gradient(165deg, var(--ink-card), var(--ink-800));
  border: 1px solid var(--ink-line); border-radius: 16px; padding: 15px 16px; }
.at-ico { width: 46px; height: 46px; border-radius: 50%; background: rgba(255,255,255,.03); border: 1px solid var(--ink-line);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.at-ico svg { width: 23px; height: 23px; stroke: var(--raio); fill: none; stroke-width: 1.7; stroke-linecap:round; stroke-linejoin:round; }
.at-body h4 { font-size: 15.5px; font-weight: 700; color: var(--white-warm); margin-bottom: 4px; }
.at-body p { font-size: 12.5px; color: var(--white-mute); line-height: 1.45; }
/* card final destacado */
.at-card-final { border-color: var(--raio); background: linear-gradient(165deg, #1a1608, #120f04);
  box-shadow: 0 0 0 1px var(--raio-bg) inset, 0 14px 36px -18px var(--raio-glow); }
.at-card-final .at-ico { background: var(--raio-bg); border-color: var(--raio-border); }
.at-card-final .at-ico svg { fill: var(--raio); }
/* CTA */
.at-cta { gap: 10px; margin-top: 24px; }
.at-cta-bolt { width: 18px; height: 18px; fill: currentColor; stroke: none; }
/* rodapé */
.at-foot { display: flex; align-items: center; justify-content: center; gap: 7px; font-size: 12.5px; color: var(--white-mute); margin-top: 16px; text-align: center; }
.at-foot svg { width: 15px; height: 15px; stroke: var(--raio); fill: none; stroke-width: 1.8; flex-shrink: 0; }
.at-foot span { color: var(--raio); font-weight: 600; }

/* pill "última pergunta" (Q5 equivalência) */
.q-pill { display: inline-flex; align-items: center; gap: 7px; background: var(--raio); color: #fff;
  font-size: 11px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; padding: 7px 15px;
  border-radius: 99px; margin-bottom: 14px; box-shadow: 0 8px 22px -10px var(--raio-glow); }
.q-pill svg { width: 13px; height: 13px; fill: #fff; }
.tela.light .eyebrow.neutra { margin-bottom: 12px; }

/* botão WhatsApp premium (suporte humano · ativação) */
.btn-wa-pro { background: rgba(37,211,102,.10); border: 1.5px solid rgba(37,211,102,.42); color: #3DDC7F;
  font-weight: 700; gap: 11px; box-shadow: 0 8px 24px -15px rgba(37,211,102,.55); transition: background .2s, border-color .2s, transform .15s, box-shadow .25s; }
.btn-wa-pro:hover { background: rgba(37,211,102,.16); border-color: #25D366; transform: translateY(-2px); box-shadow: 0 14px 32px -12px rgba(37,211,102,.5); }
.btn-wa-pro .wa-ic { width: 26px; height: 26px; border-radius: 50%; background: #25D366; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 0 14px rgba(37,211,102,.5); }
.btn-wa-pro .wa-ic svg { width: 15px; height: 15px; fill: #04210F; }
