/* ═══════════════════════════════════════════════════════
   Quiz de literacia financeira — estilos próprios (Ulclato)
   Usa as variáveis de styles.css: --bg, --ink, --coral,
   --yellow, --teal, --blue, --muted, --sh, --sh-sm
   ═══════════════════════════════════════════════════════ */

.quiz-shell{max-width:720px;margin:0 auto;padding:34px 0 10px}

/* ecrãs (um de cada vez) */
.screen{display:none}
.screen.is-active{display:block;animation:qpop .45s cubic-bezier(.22,1,.36,1)}
@keyframes qpop{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* botões .cta usados como <button> */
.quiz-shell button.cta{font-family:inherit;line-height:1.2}

/* chip amarelo (overline) */
.quiz-chip{display:inline-flex;align-items:center;gap:8px;background:var(--yellow);
  border:2px solid var(--ink);border-radius:30px;padding:6px 14px;font-size:12px;
  font-weight:700;text-transform:uppercase;letter-spacing:.6px;box-shadow:var(--sh-sm);
  margin-bottom:22px}

/* ─── intro ─── */
.screen-intro{text-align:center;padding-top:14px}
.screen-intro h1{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:clamp(28px,7vw,52px);line-height:1.05;letter-spacing:-1px;margin:0 0 16px}
.quiz-lead{max-width:540px;margin:0 auto 26px;font-size:16.5px;line-height:1.55;color:#3b362d}
.intro-points{list-style:none;margin:0 auto 4px;padding:16px 20px;max-width:440px;text-align:left;
  background:var(--white);border:2.5px solid var(--ink);border-radius:16px;box-shadow:var(--sh-sm)}
.intro-points li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;font-weight:500;
  padding:9px 0;border-bottom:2px dashed var(--line)}
.intro-points li:last-child{border-bottom:0}
.intro-points li span{color:var(--teal);font-weight:800;flex-shrink:0}
.intro-note{margin:18px 0 0;font-size:13px;color:var(--muted);font-style:italic}

/* ─── cabeçalho do quiz ─── */
.quiz-header{margin-bottom:26px}
.quiz-progress{width:100%;height:16px;background:var(--white);border:2px solid var(--ink);
  border-radius:999px;overflow:hidden;box-shadow:var(--sh-sm)}
.quiz-progress-fill{height:100%;width:0;background:var(--coral);
  transition:width .45s cubic-bezier(.22,1,.36,1)}
.quiz-meta{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.quiz-counter{font-size:12px;letter-spacing:.8px;text-transform:uppercase;font-weight:700;color:var(--muted)}
.quiz-timer{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:16px;
  color:var(--coral);font-variant-numeric:tabular-nums}

/* ─── cartão da pergunta ─── */
.quiz-card{background:var(--white);border:2.5px solid var(--ink);border-radius:20px;
  padding:clamp(20px,4vw,30px);box-shadow:var(--sh)}
.quiz-area{display:inline-flex;background:var(--bg);border:2px solid var(--ink);border-radius:20px;
  padding:4px 12px;font-size:10.5px;letter-spacing:.8px;text-transform:uppercase;font-weight:700;
  margin-bottom:14px}
.quiz-question{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;
  font-size:clamp(20px,4.5vw,27px);line-height:1.25;letter-spacing:-.4px;margin:0 0 22px}

/* opções */
.quiz-options{display:flex;flex-direction:column;gap:12px}
.quiz-option{width:100%;text-align:left;background:var(--white);border:2px solid var(--ink);
  border-radius:13px;padding:15px 16px;font-size:15px;line-height:1.45;font-weight:500;
  color:var(--ink);cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:13px;
  transition:transform .12s,box-shadow .12s,background .12s}
.quiz-option .opt-letter{flex-shrink:0;width:32px;height:32px;border-radius:9px;
  border:2px solid var(--ink);background:var(--bg);display:grid;place-items:center;
  font-family:"Bricolage Grotesque",sans-serif;font-size:14px;font-weight:800;
  transition:background .12s,color .12s}
.quiz-option:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:var(--sh-sm)}
.quiz-option:active:not(:disabled){transform:translate(1px,1px);box-shadow:none}
.quiz-option.is-picked{background:var(--yellow);transform:translate(-1px,-1px);box-shadow:var(--sh-sm)}
.quiz-option.is-picked .opt-letter{background:var(--coral);border-color:var(--ink);color:#fff}
.quiz-option:disabled{cursor:default}
.quiz-option:disabled:not(.is-picked){opacity:.55}

/* ─── suspense ─── */
.screen-calc{text-align:center;padding:clamp(50px,14vw,110px) 0}
.calc-shape{width:118px;height:118px;margin:0 auto 34px;background:var(--coral);
  border:2.5px solid var(--ink);border-radius:24px;box-shadow:var(--sh);
  display:grid;place-items:center;color:#fff;font-size:46px;
  animation:calc-wobble 1.1s ease-in-out infinite alternate}
@keyframes calc-wobble{from{transform:rotate(-8deg) scale(.9)}to{transform:rotate(8deg) scale(1.06)}}
.calc-message{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;
  font-size:clamp(17px,3vw,21px);color:var(--ink);min-height:1.6em;transition:opacity .25s}

/* ─── resultado ─── */
.screen-result{text-align:center}
.result-orb{width:160px;height:160px;margin:6px auto 24px;background:var(--coral);
  border:2.5px solid var(--ink);border-radius:50%;box-shadow:var(--sh);
  display:flex;align-items:center;justify-content:center;
  animation:result-pop .6s cubic-bezier(.34,1.4,.64,1)}
@keyframes result-pop{from{transform:scale(.55);opacity:0}to{transform:scale(1);opacity:1}}
.result-score{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;color:#fff;
  font-size:56px;line-height:1;font-variant-numeric:tabular-nums}
.result-score small{font-size:21px;font-weight:700;opacity:.85}
.result-tier{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:clamp(25px,5vw,36px);letter-spacing:-.8px;line-height:1.1;margin:0 0 10px}
.result-copy{color:#3b362d;font-size:15.5px;line-height:1.55;max-width:540px;margin:0 auto 30px}

/* bloco CTA (cartão escuro, como a newsletter) */
.result-cta{background:var(--ink);color:var(--bg);border:2.5px solid var(--ink);border-radius:20px;
  padding:clamp(26px,5vw,38px) clamp(20px,4vw,32px);margin-bottom:18px;box-shadow:var(--sh)}
.result-cta h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;color:#fff;
  font-size:clamp(20px,3.5vw,25px);letter-spacing:-.4px;line-height:1.2;margin:0 0 10px}
.result-cta p{color:#e7ddcb;font-size:14.5px;line-height:1.6;margin:0}
.result-cta .cta{margin-top:22px}

/* partilha WhatsApp */
.result-share{background:var(--white);border:2.5px solid var(--ink);border-radius:20px;
  padding:26px 22px;margin-bottom:8px;box-shadow:var(--sh-sm)}
.share-lead{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:clamp(19px,3vw,23px);letter-spacing:-.4px;margin:0 0 5px}
.share-sub{font-size:14px;color:var(--muted);margin:0 0 18px;line-height:1.5}
.share-btn{display:inline-flex;align-items:center;gap:10px;background:var(--teal);color:#fff;
  border:2.5px solid var(--ink);border-radius:14px;padding:13px 24px;font-weight:700;font-size:15px;
  box-shadow:var(--sh-sm);text-decoration:none;transition:transform .12s,box-shadow .12s}
.share-btn:hover{transform:translate(-2px,-2px);box-shadow:var(--sh)}
.share-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.share-btn svg{flex-shrink:0}

/* nota "análise detalhada em baixo" */
.detail-note{font-size:13px;color:var(--muted);font-style:italic;margin:0 0 30px;padding-top:14px}
.detail-note span{color:var(--coral);font-style:normal;font-weight:700}

/* comparação com os estudos */
.result-compare{background:var(--white);border:2.5px solid var(--ink);border-radius:20px;
  padding:26px 22px;margin-bottom:18px;text-align:left;box-shadow:var(--sh-sm)}
.result-compare h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:19px;
  letter-spacing:-.3px;margin:0 0 18px;text-align:center}
.compare-bars{display:flex;flex-direction:column;gap:14px}
.compare-bar{display:grid;grid-template-columns:104px minmax(0,1fr) 46px;align-items:center;gap:10px}
.cb-label{font-size:11px;letter-spacing:.5px;text-transform:uppercase;font-weight:700;color:var(--muted)}
.cb-track{height:18px;background:var(--bg);border:2px solid var(--ink);border-radius:999px;overflow:hidden}
.cb-fill{height:100%;width:0;transition:width 1.2s cubic-bezier(.22,1,.36,1)}
.cb-fill--you{background:var(--coral)}
.cb-fill--avg{background:var(--blue)}
.cb-value{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:16px;
  text-align:right;font-variant-numeric:tabular-nums}
.compare-note{margin:16px 0 0;font-size:12.5px;color:var(--muted);font-style:italic;
  text-align:center;line-height:1.5}

/* análise por área */
.result-areas{background:var(--white);border:2.5px solid var(--ink);border-radius:20px;
  padding:26px 22px;margin-bottom:18px;text-align:left;box-shadow:var(--sh-sm)}
.result-areas h3{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:19px;
  letter-spacing:-.3px;margin:0 0 12px;text-align:center}
.area-list{display:flex;flex-direction:column}
.area-row{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 0;border-bottom:2px dashed var(--line)}
.area-row:last-child{border-bottom:0}
.area-name{font-size:14.5px;font-weight:600}
.area-result{font-size:12px;font-weight:700;padding:5px 12px;border-radius:20px;
  border:2px solid var(--ink);white-space:nowrap}
.area-result--good{background:var(--teal);color:#fff}
.area-result--mid{background:var(--yellow);color:var(--ink)}
.area-result--low{background:var(--white);color:var(--muted)}

/* tempo */
.result-time{font-size:13px;color:var(--muted);margin-bottom:20px}

/* repetir */
.restart-link{background:none;border:none;color:var(--muted);font-size:13.5px;font-weight:600;
  font-family:inherit;text-decoration:underline;text-underline-offset:3px;cursor:pointer;
  padding:8px;transition:color .15s}
.restart-link:hover{color:var(--coral)}

/* disclaimer (antes do footer Ulclato) */
.quiz-disclaimer{margin:56px auto 0;max-width:560px;text-align:center;font-size:12px;
  color:var(--muted);font-style:italic;line-height:1.55}

/* ─── mobile (≤420px) ─── */
@media(max-width:420px){
  .compare-bar{grid-template-columns:84px minmax(0,1fr) 40px;gap:8px}
  .cb-label{font-size:10px}
  .calc-shape{width:96px;height:96px;font-size:38px}
  .result-orb{width:136px;height:136px}
  .result-score{font-size:46px}
}

/* ─── reduced motion ─── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
  }
}
