/* ============================================================
   GUIA DO PISM — Design System (DARK MODE)
   Vibe: moderna, tecnológica, roxo neon sobre fundo escuro
   ============================================================ */
:root{
  --bg:#0e0717;
  --bg-2:#150b24;
  --surface:#1b1230;
  --surface-2:#241738;
  --surface-3:#2c1d45;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --text:#f3eefb;
  --muted:#a99dc4;
  --muted-2:#7d7397;

  --roxo:#a020f0;
  --roxo-2:#8B00C9;
  --magenta:#d11ad6;
  --rosa:#F03080;
  --ambar:#E59A18;
  --menta:#3fd9a6;
  --verde:#22c98a;

  --grad:linear-gradient(135deg,#8B00C9 0%,#c01ad6 55%,#e0149e 100%);
  --grad-soft:linear-gradient(135deg,rgba(139,0,201,.18),rgba(224,20,158,.14));

  --radius:18px;
  --radius-sm:12px;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --shadow-glow:0 10px 34px rgba(160,32,240,.35);
  --font:"Segoe UI",Roboto,"Helvetica Neue",system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--text);
  background-color:var(--bg);
  background-image:
    radial-gradient(1100px 600px at 80% -8%,rgba(160,32,240,.22),transparent 60%),
    radial-gradient(900px 600px at 0% 110%,rgba(224,20,158,.16),transparent 55%),
    linear-gradient(180deg,#0e0717,#0b0512 70%);
  background-repeat:no-repeat,no-repeat,no-repeat;
  background-size:auto,auto,auto;
  background-position:center,center,center;
  line-height:1.55;-webkit-font-smoothing:antialiased;
  min-height:100vh;
}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:30;background:#120a1f;border-bottom:1px solid var(--line)}
.topbar-inner{max-width:1080px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.brand-logo{height:70px;width:auto;max-width:100%;object-fit:contain;display:block}

/* ---------- Decorativo: hexágonos concêntricos nos cantos ---------- */
.hex-decor{position:fixed;z-index:-1;pointer-events:none;background-repeat:no-repeat;background-size:contain;background-position:center}
/* maior — canto inferior direito, sangra pra fora (só uma porção aparece) */
.hex-decor.hex-br{right:-260px;bottom:-260px;width:680px;height:680px;background-image:url("../assets/hex-corner.svg?v=4");opacity:.8}
/* menor — lado superior esquerdo, sangra pra fora */
.hex-decor.hex-tl{left:-220px;top:13%;width:440px;height:440px;background-image:url("../assets/hex-corner.svg?v=4");opacity:.5}
.stepper{display:flex;gap:7px;margin-left:auto;flex-wrap:wrap}
.step{font-size:12px;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);padding:6px 13px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.step.done{color:var(--text);background:rgba(160,32,240,.16);border-color:rgba(160,32,240,.35)}
.step.current{color:#fff;background:var(--grad);border-color:transparent;box-shadow:var(--shadow-glow)}

/* ---------- Layout ---------- */
.container{max-width:1080px;margin:0 auto;padding:34px 20px 70px}
.screen{display:none;animation:fade .35s ease}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.screen-grid{display:grid;grid-template-columns:minmax(280px,400px) 1fr;gap:34px;align-items:center}
.mascot-pane{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.mascot{width:100%;max-width:330px;height:auto;margin:0 auto 6px}
.pane-title{font-size:30px;line-height:1.12;margin:6px 0 4px;font-weight:800}
.pane-title .hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.pane-sub{color:var(--muted);font-size:15.5px;margin:0;max-width:44ch}

/* ---------- Cards & forms ---------- */
.card{background:linear-gradient(180deg,var(--surface),#170e29);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 26px}
.card-title{margin:0 0 4px;font-size:22px;font-weight:800}
.card-sub{margin:0 0 22px;color:var(--muted);font-size:14.5px}

.field{margin-bottom:17px;display:flex;flex-direction:column}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
label{font-weight:600;font-size:13.5px;margin-bottom:7px;color:#e7defb}
.muted{font-weight:400;color:var(--muted)}
input[type=text],input[type=email],input[type=tel],select{
  font:inherit;padding:13px 14px;border:1px solid var(--line-2);border-radius:var(--radius-sm);
  background:var(--surface-2);color:var(--text);transition:border-color .15s,box-shadow .15s;width:100%;
}
input::placeholder{color:var(--muted-2)}
select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 20px) 53%,calc(100% - 14px) 53%;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:38px}
select option{background:#1b1230;color:var(--text)}
input:focus,select:focus{outline:none;border-color:var(--roxo);box-shadow:0 0 0 4px rgba(160,32,240,.22)}
.hint{color:var(--muted);font-size:12.5px;margin-top:7px}
.hint strong{color:#e7defb}
.err{color:#ff6b9d;font-size:12.5px;margin-top:6px;font-weight:600;min-height:0}
.field.invalid input,.field.invalid select{border-color:var(--rosa);box-shadow:0 0 0 4px rgba(240,48,128,.2)}
.check-inline{font-weight:400;font-size:13px;color:var(--muted);margin-top:9px;display:flex;align-items:center;gap:8px}
.check-inline input{width:auto;accent-color:var(--roxo)}

/* ---------- Radio cards ---------- */
.radio-row{display:flex;gap:12px;flex-wrap:wrap}
.radio-card{flex:1;min-width:150px;display:flex;align-items:center;gap:10px;padding:14px 16px;border:1px solid var(--line-2);border-radius:var(--radius-sm);cursor:pointer;font-weight:600;transition:all .15s;background:var(--surface-2);color:var(--text)}
.radio-card:hover{border-color:var(--roxo)}
.radio-card input{accent-color:var(--roxo)}
.radio-card:has(input:checked){border-color:transparent;background:var(--grad);box-shadow:var(--shadow-glow)}

/* ---------- Identidade banner (Tela 2) ---------- */
.ident-banner{display:flex;align-items:flex-start;gap:12px;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:22px;font-size:14px;border:1px solid}
.ident-banner .ib-ic{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.ident-banner.ok{background:rgba(34,201,138,.10);border-color:rgba(34,201,138,.45)}
.ident-banner.ok .ib-ic{background:rgba(34,201,138,.2);color:#5ff0bd}
.ident-banner.warn{background:rgba(229,154,24,.10);border-color:rgba(229,154,24,.45)}
.ident-banner.warn .ib-ic{background:rgba(229,154,24,.2);color:#ffc465}
.ident-banner.info{background:rgba(160,32,240,.10);border-color:rgba(160,32,240,.4)}
.ident-banner.info .ib-ic{background:rgba(160,32,240,.2);color:#cf8bff}
.ident-banner b{color:#fff}

/* ---------- Autoavaliação (tópico a tópico) ---------- */
.subj-group{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:14px;overflow:hidden;background:var(--surface)}
.subj-group-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 16px;background:var(--surface-3);flex-wrap:wrap}
.subj-group-head .sg-name{font-weight:800;font-size:15.5px}
.peso-tag{font-size:11px;font-weight:700;background:rgba(240,48,128,.18);color:#ff7eae;border:1px solid rgba(240,48,128,.4);padding:3px 9px;border-radius:999px}
.quickfill{display:flex;gap:6px;align-items:center}
.quickfill span{font-size:11px;color:var(--muted-2)}
.qf-btn{font-size:11px;font-weight:700;border:1px solid var(--line-2);background:var(--surface-2);color:var(--muted);border-radius:999px;padding:4px 10px;cursor:pointer}
.qf-btn:hover{border-color:var(--roxo);color:var(--text)}
.topic-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 16px;border-top:1px solid var(--line);flex-wrap:wrap}
.topic-name{font-size:14px;flex:1;min-width:180px}
.seg{display:flex;gap:6px;flex-wrap:wrap}
.seg label{font-weight:600;font-size:12px;margin:0;border:1px solid var(--line-2);border-radius:999px;padding:6px 12px;cursor:pointer;transition:all .12s;background:var(--surface-2);color:var(--muted);white-space:nowrap}
.seg input{display:none}
.seg label.lvl0:has(input:checked){background:rgba(240,48,128,.16);border-color:var(--rosa);color:#ff7eae}
.seg label.lvl1:has(input:checked){background:rgba(229,154,24,.16);border-color:var(--ambar);color:#ffc465}
.seg label.lvl2:has(input:checked){background:rgba(34,201,138,.16);border-color:var(--verde);color:#5ff0bd}

/* ---------- Buttons ---------- */
.btn{font:inherit;font-weight:700;border:none;border-radius:999px;padding:14px 28px;cursor:pointer;transition:transform .12s,box-shadow .12s,filter .15s;color:#fff}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--grad);box-shadow:var(--shadow-glow)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-amber{background:linear-gradient(135deg,#E59A18,#f0b94e);color:#231400;box-shadow:0 8px 22px rgba(229,154,24,.3)}
.btn-ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--roxo)}
.btn-restart{background:transparent;color:var(--muted);border:1px solid var(--line-2)}
.btn-block{width:100%;margin-top:10px}
.actions{display:flex;gap:12px;justify-content:space-between;margin-top:26px;flex-wrap:wrap}
.actions .btn{flex:1;min-width:150px}

/* ---------- Result ---------- */
.result-head{margin-bottom:18px}
.result-head h2{margin:0;font-size:24px}
.result-head .who{color:var(--muted);font-size:14px;margin-top:4px}

.status-card{border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);position:relative;overflow:hidden;margin-bottom:22px;border:1px solid var(--line-2)}
.status-card .badge{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;background:rgba(0,0,0,.25);padding:5px 12px;border-radius:999px;margin-bottom:12px}
.status-card h3{margin:0 0 10px;font-size:27px;line-height:1.12;max-width:80%}
.status-card p{margin:0;font-size:15px;opacity:.97;max-width:62ch}
.status-card .duck{position:absolute;right:8px;bottom:-6px;width:150px}
.status-otima{background:linear-gradient(135deg,#0c8f5f,#22c98a)}
.status-aceitavel{background:linear-gradient(135deg,#b9760a,#e9a82e)}
.status-cuidado{background:linear-gradient(135deg,#b9560a,#e07a2e)}
.status-limitrofe{background:linear-gradient(135deg,#c0166a,#E59A18)}
.status-complicada{background:linear-gradient(135deg,#9e0f49,#F03080)}
.status-neutro{background:var(--grad)}

.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:13px;margin-bottom:22px}
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px}
.metric .mic{width:38px;height:38px;border-radius:10px;background:var(--grad-soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:#cf8bff}
.metric .lbl{font-size:12px;color:var(--muted);font-weight:600}
.metric .val{font-size:25px;font-weight:800;margin-top:3px}
.metric .sub{font-size:11.5px;color:var(--muted-2);margin-top:2px}
.metric.accent .val{color:#ff7eae}

.gauge{height:13px;border-radius:999px;background:var(--surface-3);overflow:hidden;margin:8px 0 4px}
.gauge>span{display:block;height:100%;border-radius:999px;background:var(--grad)}
.gauge-row{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted-2)}

.block{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin-bottom:18px}
.block h4{margin:0 0 14px;font-size:18px;font-weight:800}
.block.mentoria{border-color:rgba(240,48,128,.4);background:linear-gradient(180deg,rgba(240,48,128,.08),var(--surface))}
.block.founders{border-color:rgba(229,154,24,.4);background:linear-gradient(180deg,rgba(229,154,24,.08),var(--surface))}
.block p{color:#d9d0ea}

.subj-bars{display:flex;flex-direction:column;gap:10px}
.subj-bar{display:grid;grid-template-columns:150px 1fr 50px;align-items:center;gap:12px;font-size:13.5px}
.subj-bar .nm{font-weight:600}
.bar{height:11px;border-radius:999px;background:var(--surface-3);overflow:hidden}
.bar>span{display:block;height:100%;border-radius:999px}
.bar.good>span{background:linear-gradient(90deg,#0c8f5f,#22c98a)}
.bar.mid>span{background:linear-gradient(90deg,#b9760a,#e9a82e)}
.bar.low>span{background:linear-gradient(90deg,#c0166a,#F03080)}
.subj-bar .pc{text-align:right;font-weight:700;font-variant-numeric:tabular-nums}

.tag{display:inline-block;background:rgba(160,32,240,.16);color:#cf8bff;border:1px solid rgba(160,32,240,.32);font-weight:600;font-size:12.5px;padding:4px 11px;border-radius:999px;margin:3px 5px 3px 0}
.tag.warn{background:rgba(240,48,128,.14);color:#ff7eae;border-color:rgba(240,48,128,.34)}
.tag.ok{background:rgba(34,201,138,.14);color:#5ff0bd;border-color:rgba(34,201,138,.34)}

.todo{margin:0;padding:0;list-style:none}
.todo li{position:relative;padding:8px 0 8px 30px;border-bottom:1px solid var(--line);color:#d9d0ea}
.todo li:last-child{border-bottom:none}
.todo li:before{content:"";position:absolute;left:2px;top:13px;width:9px;height:9px;border-radius:50%;background:var(--grad)}
.todo li b,.block p b{color:#fff}
.plan-sub{margin:18px 0 6px;font-weight:800;color:#cf8bff;font-size:14px}
.topiclist{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}

.cta-ig{display:flex;align-items:center;gap:16px;background:var(--grad);border-radius:var(--radius);padding:20px 22px;margin-bottom:18px;flex-wrap:wrap}
.cta-ig img{width:88px;border-radius:10px;background:#fff;padding:5px}
.cta-ig a{color:#fff;font-weight:800;text-decoration:underline}
.cta-ig .btn{background:#fff;color:var(--roxo-2);flex:0 0 auto}
.cta-ig .ig-txt{flex:1;min-width:200px}

.note{font-size:12.5px;color:var(--muted);background:rgba(229,154,24,.08);border:1px solid rgba(229,154,24,.4);border-radius:10px;padding:11px 13px;margin-bottom:16px}

.sitefoot{text-align:center;color:var(--muted-2);font-size:12.5px;padding:24px 16px 44px}

/* ---------- Responsivo ---------- */
@media(max-width:780px){
  .screen-grid{grid-template-columns:1fr;gap:18px}
  .mascot-pane{align-items:center;text-align:center}
  .mascot{max-width:200px}
  .pane-title{font-size:24px}
  .pane-sub{font-size:14px}
  .brand-logo{height:48px}
  .hex-decor.hex-br{width:460px;height:460px;right:-200px;bottom:-200px}
  .hex-decor.hex-tl{display:none}
}
@media(max-width:620px){
  .grid-2{grid-template-columns:1fr}
  .subj-bar{grid-template-columns:110px 1fr 44px}
  .stepper{display:none}
  .status-card .duck{width:96px;opacity:.5}
  .status-card h3{max-width:100%}
  .brand-logo{height:39px}
}

/* ============================================================
   IMPRESSÃO / PDF  (fundo claro p/ leitura e tinta)
   ============================================================ */
@media print{
  @page{margin:13mm}
  body{background:#fff;background-image:none;color:#201430}
  .hex-decor{display:none !important}
  .topbar,.sitefoot,.no-print,.actions{display:none !important}
  .container{max-width:none;padding:0}
  .screen{display:none !important}
  #screen-4.active{display:block !important}
  .card,.block,.metric{background:#fff;border:1px solid #e4dcef;box-shadow:none}
  .block p,.todo li{color:#312447}
  .metric .val{color:#6a009b}
  .tag{background:#f1e6fb;color:#6a009b;border-color:#e1cef7}
  .bar,.gauge{background:#eee}
  .pdf-header{display:flex !important}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .status-card,.block,.cta-ig,.metrics,.subj-group{break-inside:avoid}
}
.pdf-header{display:none;align-items:center;justify-content:space-between;border-bottom:3px solid #8B00C9;padding-bottom:10px;margin-bottom:18px}
.pdf-header img{height:34px}
.pdf-header .pdf-meta{font-size:11px;color:#6b6480;text-align:right}

/* ============================================================
   COMPONENTES NOVOS
   ============================================================ */
/* chips de seleção única (matéria de maior dificuldade) */
.chip-grid{display:flex;flex-wrap:wrap;gap:9px;margin-top:2px}
.chip{padding:9px 15px;border:1px solid var(--line-2);border-radius:999px;cursor:pointer;font-weight:600;font-size:13.5px;background:var(--surface-2);color:var(--text);user-select:none;transition:all .15s}
.chip:hover{border-color:var(--roxo)}
.chip.sel{background:var(--grad);border-color:transparent;box-shadow:var(--shadow-glow);color:#fff}

/* escala MBTI (5 pontos / bolinhas) */
.q-item{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:10px;background:var(--surface)}
.q-text{font-size:14.5px;font-weight:600;margin-bottom:12px}
.q-text .qn{color:var(--muted-2);font-weight:800;margin-right:6px}
.scale5{display:flex;align-items:center;gap:12px}
.scale5 .lbl{font-size:11.5px;color:var(--muted-2);min-width:60px;font-weight:600}
.scale5 .lbl.r{text-align:right}
.dots{display:flex;gap:14px;flex:1;justify-content:center}
.dot{position:relative;width:26px;height:26px}
.dot input{position:absolute;inset:0;opacity:0;cursor:pointer;margin:0;z-index:2}
.dot .vis{position:absolute;inset:0;border-radius:50%;border:2px solid var(--line-2);background:var(--surface-2);transition:all .12s;pointer-events:none;z-index:1}
.dot input:hover + .vis{border-color:var(--roxo)}
.dot input:checked + .vis{background:var(--grad);border-color:transparent;box-shadow:0 0 0 4px rgba(160,32,240,.18)}
@media(max-width:620px){ .scale5 .lbl{min-width:46px;font-size:10.5px} .dots{gap:8px} .dot{width:22px;height:22px} }

/* 4º nível da autoavaliação ("Consigo resolver questões") */
.seg label.lvl3:has(input:checked){background:rgba(160,32,240,.20);border-color:var(--roxo);color:#cf8bff}

/* bloco comportamental no diagnóstico */
.behav-score{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:12.5px;padding:5px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--line-2);margin-bottom:12px}
.block.behav-pessimo{border-color:rgba(240,48,128,.5);background:linear-gradient(180deg,rgba(240,48,128,.12),var(--surface))}
.block.behav-ruim{border-color:rgba(229,154,24,.5);background:linear-gradient(180deg,rgba(229,154,24,.10),var(--surface))}
.block.behav-otimo{border-color:rgba(63,217,166,.5);background:linear-gradient(180deg,rgba(63,217,166,.08),var(--surface))}
.block.behav-excelente{border-color:rgba(34,201,138,.55);background:linear-gradient(180deg,rgba(34,201,138,.12),var(--surface))}
.block.hardest{border-color:rgba(160,32,240,.4);background:linear-gradient(180deg,rgba(160,32,240,.08),var(--surface))}

/* ---------- Plano de ação: blocos de urgência (Seções 1 a 4) ---------- */
.block.sec h4{display:flex;align-items:center;gap:10px;font-size:18px}
.block.sec .sec-dot{width:13px;height:13px;border-radius:50%;flex:0 0 auto}
.block.sec p{margin:0 0 13px;color:#e2dcef}
.block.sec p:last-child{margin-bottom:0}
.block.sec .sec-lead{font-weight:800;color:#fff;margin-bottom:6px}
.block.sec .sec-lead + p{margin-top:0}
.block.sec .behav-class{font-size:14.5px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.block.sec .todo li{color:#e2dcef}
.block.sec-urgent{border-color:rgba(240,48,128,.55);background:linear-gradient(180deg,rgba(240,48,128,.13),var(--surface))}
.block.sec-urgent .sec-dot{background:#F03080;box-shadow:0 0 12px rgba(240,48,128,.7)}
.block.sec-essential{border-color:rgba(229,154,24,.55);background:linear-gradient(180deg,rgba(229,154,24,.12),var(--surface))}
.block.sec-essential .sec-dot{background:#E59A18;box-shadow:0 0 12px rgba(229,154,24,.7)}
.block.sec-important{border-color:rgba(90,155,240,.55);background:linear-gradient(180deg,rgba(90,155,240,.12),var(--surface))}
.block.sec-important .sec-dot{background:#5a9bf0;box-shadow:0 0 12px rgba(90,155,240,.7)}
.block.sec-env{border-color:rgba(63,217,166,.55);background:linear-gradient(180deg,rgba(63,217,166,.12),var(--surface))}
.block.sec-env .sec-dot{background:#3fd9a6;box-shadow:0 0 12px rgba(63,217,166,.7)}

/* ---------- Vitrine de aprovados (Tela 5) — masonry de artes inteiras ---------- */
.aprov-block{border-color:rgba(160,32,240,.34)}
.aprov-grid{column-count:4;column-gap:12px;margin-top:8px}
.aprov-card{break-inside:avoid;position:relative;margin:0 0 12px;display:block}
.aprov-img{width:100%;height:auto;display:block;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--surface-2);cursor:zoom-in;transition:filter .15s,transform .15s}
.aprov-img:hover{filter:brightness(1.06)}
.aprov-badge{position:absolute;left:8px;top:8px;font-size:10px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;background:var(--grad);color:#fff;padding:3px 9px;border-radius:999px;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.aprov-fb{display:block;width:100%;margin-top:7px;font:inherit;font-size:12px;font-weight:700;border:1px solid var(--line-2);background:rgba(160,32,240,.16);color:#cf8bff;border-radius:999px;padding:7px 12px;cursor:pointer;transition:all .15s}
.aprov-fb:hover{border-color:var(--roxo);background:rgba(160,32,240,.26);color:#fff}
@media(max-width:980px){ .aprov-grid{column-count:3} }
@media(max-width:680px){ .aprov-grid{column-count:2} }

/* Modal do depoimento */
.aprov-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.aprov-modal[hidden]{display:none}
.aprov-modal-backdrop{position:absolute;inset:0;background:rgba(6,3,12,.82);backdrop-filter:blur(2px)}
.aprov-modal-box{position:relative;max-width:560px;width:100%;max-height:88vh;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,.6);padding:16px;display:flex;flex-direction:column;overflow:hidden}
.aprov-modal-cap{font-size:13.5px;color:var(--muted);margin:0 36px 10px 4px}
.aprov-modal-cap strong{color:#fff}
.aprov-modal-img,#aprov-modal-img{width:100%;height:auto;max-height:74vh;object-fit:contain;border-radius:var(--radius-sm);background:#0d0717}
.aprov-modal-x{position:absolute;top:10px;right:12px;width:34px;height:34px;border:none;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;font-size:22px;line-height:1;cursor:pointer;transition:background .15s}
.aprov-modal-x:hover{background:rgba(255,255,255,.18)}
@media(max-width:620px){ .aprov-grid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:10px} }

/* ============================================================
   SEÇÃO DE CONVERSÃO — Intensivo Guia do PISM (CTA final)
   ============================================================ */
.offer{margin-top:30px;padding-top:26px;border-top:1px solid var(--line-2)}
.offer-h2{text-align:center;font-size:27px;line-height:1.18;font-weight:800;max-width:760px;margin:0 auto 22px}
.offer-sec-title{text-align:center;font-size:20px;font-weight:800;margin:34px 0 16px}

/* --- Mentores --- */
.mentors{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:26px}
.mentor{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px}
.mentor-photo{width:58px;height:58px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:2px solid var(--roxo)}
.mentor-ini{width:58px;height:58px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;color:#fff;background:var(--grad)}
.mentor-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.mentor-info b{font-size:15px}
.mentor-info span{font-size:12px;color:var(--muted)}
.mentor-info strong{color:#5ff0bd}

/* --- Flip cards --- */
.pinned-grid{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.flip-card{flex:0 0 auto;width:190px;height:238px;perspective:1100px;cursor:pointer;border-radius:14px}
.flip-card.flip-big{width:236px;height:296px}
.flip-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.2,.7,.2,1);transform-style:preserve-3d}
.flip-card:hover .flip-inner,.flip-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-card:focus-visible{outline:2px solid var(--roxo);outline-offset:3px}
.flip-front,.flip-back{position:absolute;inset:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:14px;overflow:hidden;border:1px solid var(--line-2)}
.flip-front{background:var(--surface-2)}
.flip-front img{width:100%;height:100%;object-fit:cover;display:block}
.flip-hint{position:absolute;left:0;right:0;bottom:0;font-size:10.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;color:#fff;text-align:center;padding:14px 6px 7px;background:linear-gradient(transparent,rgba(8,4,16,.86))}
.flip-badge{position:absolute;top:8px;left:8px;right:8px;z-index:2;font-size:10px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;background:var(--grad);color:#fff;padding:4px 8px;border-radius:999px;text-align:center;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.flip-back{transform:rotateY(180deg);background:linear-gradient(180deg,var(--surface-3),var(--surface));display:flex;flex-direction:column;justify-content:center;gap:9px;padding:15px 14px}
.flip-quote{font-size:11.6px;line-height:1.42;color:#e7defb;overflow-y:auto;max-height:100%;font-style:italic}
.flip-author{font-size:11.5px;font-weight:800;color:#cf8bff}
.flip-big .flip-quote{font-size:12.5px}
.no-flip{cursor:zoom-in;position:relative}
.no-flip img{width:100%;height:100%;object-fit:cover;display:block;border-radius:14px;border:1px solid var(--line-2)}

/* --- Carrossel infinito --- */
.aprov-carousel{overflow:hidden;position:relative;margin-top:4px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.aprov-track{display:flex;gap:14px;width:max-content;padding:6px 0;animation:aprovScroll 80s linear infinite}
.aprov-carousel:hover .aprov-track{animation-play-state:paused}
.aprov-track:has(.flipped){animation-play-state:paused}
@keyframes aprovScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.carousel-hint{text-align:center;font-size:12px;color:var(--muted-2);margin:10px 0 0}

/* --- Copy condicional --- */
.offer-copy{text-align:center;max-width:720px;margin:34px auto 6px}
.offer-copy h3{font-size:23px;line-height:1.22;font-weight:800;margin:0 0 8px}
.offer-copy p{font-size:15px;color:var(--muted);margin:0}

/* --- Vídeos (3 pilares 9:16) --- */
.videos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:920px;margin:0 auto}
.video-pillar{width:100%;max-width:290px;margin:0 auto;display:flex;flex-direction:column}
.video-pillar h5{margin:0 0 9px;font-size:15px;font-weight:800;text-align:center;color:#fff}
.video-frame{border-radius:14px;overflow:hidden;border:1px solid var(--line-2);background:#000;box-shadow:0 14px 36px rgba(0,0,0,.4)}
.video-cap{text-align:center;font-size:12px;color:var(--muted);margin:9px 0 0}

/* --- Pricing (LIGHT THEME obrigatório) --- */
.pricing{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:760px;margin:0 auto}
.price-card{position:relative;background:#ffffff;color:#241a38;border:1px solid #e7e0f2;border-radius:18px;padding:26px 24px;display:flex;flex-direction:column;box-shadow:0 16px 40px rgba(0,0,0,.28)}
.price-card.featured{border:2px solid #2bbd92;box-shadow:0 20px 52px rgba(43,189,146,.28);transform:translateY(-4px)}
.price-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#2bbd92,#3fd9a6);color:#06231a;font-size:11.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;padding:5px 16px;border-radius:999px;white-space:nowrap}
.price-name{font-size:14px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#6a009b}
.price-val{font-size:36px;font-weight:800;color:#0e9d72;margin:8px 0 0;line-height:1}
.price-val .price-cash{font-size:13px;font-weight:700;color:#8a8298;margin-left:8px;text-transform:uppercase;letter-spacing:.4px}
.price-parc{font-size:14px;color:#544b66;margin:6px 0 16px}
.price-parc strong{color:#241a38}
.price-feat{list-style:none;margin:0 0 20px;padding:0;display:flex;flex-direction:column;gap:10px;flex:1}
.price-feat li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;line-height:1.35}
.price-feat .pi-ic{flex:0 0 auto;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;margin-top:1px}
.pi-yes .pi-ic{background:#daf6ec;color:#0e9d72}
.pi-no{color:#9a93a8}
.pi-no .pi-ic{background:#fbe2e7;color:#d23b53}
.price-btn{display:block;text-align:center;text-decoration:none;font-weight:800;font-size:15px;padding:14px 18px;border-radius:999px;background:#efe9f8;color:#6a009b;transition:filter .15s,transform .12s}
.price-btn:hover{filter:brightness(.97)}
.price-btn.featured-btn{background:linear-gradient(135deg,#2bbd92,#3fd9a6);color:#06231a;box-shadow:0 10px 26px rgba(43,189,146,.4)}
.price-btn:active{transform:translateY(1px)}

@media(max-width:860px){
  .mentors{grid-template-columns:1fr}
  .videos-grid{grid-template-columns:1fr;max-width:330px}
}
@media(max-width:680px){
  .offer-h2{font-size:22px}
  .offer-copy h3{font-size:19px}
  .pricing{grid-template-columns:1fr;max-width:380px}
  .price-card.featured{transform:none}
  .flip-card{width:150px;height:188px}
  .flip-card.flip-big{width:175px;height:220px}
  .flip-quote{font-size:10.6px}
}
@media(prefers-reduced-motion:reduce){ .aprov-track{animation:none} }

/* --- Contato (WhatsApp) + compartilhar --- */
.contact-cta{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap;margin:30px 0 4px}
.contact-cta .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px}
.contact-cta .btn svg{flex:0 0 auto}
.btn-wpp{background:#25d366;color:#06351f}
.btn-wpp:hover{filter:brightness(1.06)}
.btn-share{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}
.btn-share:hover{filter:brightness(1.08)}
@media(max-width:560px){ .contact-cta{flex-direction:column} .contact-cta .btn{width:100%} }

/* --- Botão flutuante do WhatsApp (só ícone, cores do tema) --- */
.wpp-fab{position:fixed;right:20px;bottom:20px;z-index:90;width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;background:var(--grad);
  box-shadow:0 10px 26px rgba(160,32,240,.45),0 2px 8px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.14);
  transition:transform .15s,box-shadow .15s;text-decoration:none}
.wpp-fab:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 14px 34px rgba(160,32,240,.55)}
.wpp-fab:active{transform:scale(.97)}
@media(max-width:560px){ .wpp-fab{width:50px;height:50px;right:16px;bottom:16px} .wpp-fab svg{width:23px;height:23px} }

/* --- Oferta de pré-venda: subtítulo, preço De/por, bônus --- */
.offer-sec-sub{text-align:center;font-size:14px;color:var(--muted);max-width:640px;margin:-8px auto 18px}
.offer-sec-sub strong{color:#5ff0bd}
.price-old{font-size:17px;color:#a79db8;text-decoration:line-through;font-weight:700;margin-right:7px}
.price-feat .bonus-head{display:block;margin:6px 0 2px;padding-top:10px;border-top:1px dashed #e7e0f2;font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#c47f00}
.price-feat .pi-bonus{color:#3a2f14}
.pi-bonus .pi-ic{background:#fff2d4;color:#E59A18}

/* --- Foto do simulado presencial --- */
.simulado-presencial{max-width:430px;margin:24px auto 0;text-align:center}
.simulado-presencial img{width:100%;height:auto;display:block;border-radius:14px;border:1px solid var(--line-2);box-shadow:0 12px 30px rgba(0,0,0,.35)}
.simulado-presencial figcaption{font-size:12.5px;color:var(--muted);margin-top:10px;font-style:italic}

/* --- Botões de ação do diagnóstico: minimalistas (não competem com a compra) --- */
#screen-5 .actions{justify-content:center;gap:10px;margin-top:24px}
#screen-5 .actions .btn{flex:0 1 auto;min-width:0;background:transparent;border:1px solid var(--line-2);color:var(--muted);font-weight:600;font-size:13px;padding:10px 18px;box-shadow:none}
#screen-5 .actions .btn:hover{border-color:var(--roxo);color:var(--text);filter:none}
