/* ============================================================
   Componentes extras — auth, painéis, quiz, checkout, assinatura
   Depende dos tokens de styles.css
   ============================================================ */
.nav-account{display:inline-flex;align-items:center;gap:18px;}
.nav-account a{font-family:var(--font-ui);font-size:14px;font-weight:500;color:var(--slate);}
.nav-account a:hover{color:var(--navy-800);}

/* ---------- Página utilitária centrada ---------- */
.page{min-height:calc(100vh - 74px);padding:54px 0;}
.page-narrow{max-width:460px;margin:0 auto;}
.panel{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:36px;}
.panel h1{font-family:var(--font-display);font-size:1.9rem;color:var(--navy-800);line-height:1.1;}
.panel .sub{color:var(--slate);margin:8px 0 22px;font-size:1rem;}
.form-field{margin-bottom:14px;}
.form-field label{display:block;font-family:var(--font-ui);font-size:12px;font-weight:500;letter-spacing:.3px;
  color:var(--slate);margin-bottom:6px;}
.form-field input,.form-field textarea,.form-field select{width:100%;font-family:var(--font-ui);font-size:1rem;
  padding:13px 14px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--ink);transition:.2s;}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(203,176,121,.15);}
.form-err{background:rgba(155,44,44,.08);border:1px solid rgba(155,44,44,.3);color:var(--danger);
  font-family:var(--font-ui);font-size:13px;padding:11px 13px;border-radius:var(--radius);margin-bottom:14px;}
.switch-line{font-family:var(--font-ui);font-size:13px;color:var(--slate);text-align:center;margin-top:18px;}
.switch-line a{color:var(--gold-600);font-weight:600;}
.tabs-2{display:flex;background:var(--cream);border:1px solid var(--border);border-radius:999px;padding:4px;margin-bottom:22px;}
.tabs-2 button{flex:1;font-family:var(--font-ui);font-size:13px;font-weight:600;border:none;background:none;cursor:pointer;
  padding:10px;border-radius:999px;color:var(--slate);transition:.18s;}
.tabs-2 button.active{background:var(--navy-800);color:#fff;}

/* ---------- Checkout ---------- */
.modal-checkout{max-width:430px;}
.co-sub{color:var(--slate);font-size:.95rem;margin-top:6px;}
.co-tabs{display:flex;background:var(--cream);border:1px solid var(--border);border-radius:999px;padding:4px;margin:18px 0;}
.co-tab{flex:1;font-family:var(--font-ui);font-size:13px;font-weight:600;border:none;background:none;cursor:pointer;
  padding:10px;border-radius:999px;color:var(--slate);transition:.18s;}
.co-tab.active{background:var(--navy-800);color:#fff;}
.pix-box{display:flex;gap:18px;align-items:center;}
.pix-qr{flex-shrink:0;border:1px solid var(--border);border-radius:var(--radius);padding:6px;background:#fff;}
.pix-info .pix-amt{font-family:var(--font-ui);font-size:14px;color:var(--navy-800);}
.pix-info p{font-size:.85rem;color:var(--slate);margin:6px 0 10px;}
.pix-info .btn{margin-bottom:8px;}
.card-row{display:flex;gap:12px;}
.card-row > div{flex:1;}
.co-foot{font-family:var(--font-ui);font-size:11px;color:var(--muted);text-align:center;margin-top:16px;}
.checkout-ok{text-align:center;padding:14px 6px;}
.checkout-ok .ok-badge{width:64px;height:64px;border-radius:50%;background:var(--gold-grad);color:#fff;font-size:30px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.checkout-ok h3{font-family:var(--font-display);font-size:1.6rem;color:var(--navy-800);}
.checkout-ok p{color:var(--slate);margin:10px 0;font-size:.96rem;}
.ok-code{background:var(--cream);border:1px dashed var(--gold-300);border-radius:var(--radius);padding:12px;
  font-family:var(--font-ui);font-size:13px;color:var(--slate);margin:14px 0 18px;}
.ok-code strong{font-family:var(--font-ui);letter-spacing:2px;color:var(--navy-800);}

/* ---------- Painéis (cliente + advogado) ---------- */
.dash{max-width:var(--maxw);margin:0 auto;padding:40px 24px;}
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:28px;}
.dash-head h1{font-family:var(--font-display);font-size:2rem;color:var(--navy-800);line-height:1.1;}
.dash-head p{color:var(--slate);margin-top:4px;}
.dash-stats{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px;}
.dstat{flex:1;min-width:140px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;}
.dstat b{font-family:var(--font-display);font-size:1.8rem;color:var(--navy-800);display:block;line-height:1;}
.dstat span{font-family:var(--font-ui);font-size:12px;color:var(--slate);text-transform:uppercase;letter-spacing:.5px;}
.order-list{display:flex;flex-direction:column;gap:14px;}
.order{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;transition:.2s var(--ease);}
.order:hover{box-shadow:var(--shadow);}
.order .o-main{flex:1;min-width:200px;}
.order .o-title{font-family:var(--font-display);font-size:1.2rem;color:var(--navy-800);}
.order .o-meta{font-family:var(--font-ui);font-size:12px;color:var(--muted);margin-top:4px;}
.order .o-meta .code{color:var(--gold-600);letter-spacing:1px;}
.order .o-actions{display:flex;gap:8px;flex-wrap:wrap;}
.badge{font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;white-space:nowrap;}
.badge.rascunho{background:var(--navy-50);color:var(--navy-700);border:1px solid #D5DEEA;}
.badge.pago{background:rgba(203,176,121,.15);color:var(--gold-600);border:1px solid var(--gold-300);}
.badge.revisado{background:rgba(46,107,79,.12);color:var(--success);border:1px solid rgba(46,107,79,.3);}
.badge.assinado{background:var(--navy-800);color:#fff;}
.empty-state{background:#fff;border:1px dashed var(--border);border-radius:var(--radius-lg);padding:48px 24px;text-align:center;color:var(--slate);}
.empty-state a{color:var(--gold-600);font-weight:600;}

/* ---------- Documento em modal/visualização ---------- */
.doc-modal{position:fixed;inset:0;background:rgba(10,31,56,.7);backdrop-filter:blur(4px);z-index:120;
  display:none;justify-content:center;overflow:auto;padding:30px 16px;}
.doc-modal.open{display:flex;}
.doc-modal .dm-inner{width:210mm;max-width:100%;}
.doc-modal .dm-bar{display:flex;gap:8px;justify-content:flex-end;margin-bottom:12px;}
.dm-close{background:#fff;border:none;border-radius:999px;width:38px;height:38px;font-size:20px;cursor:pointer;}

/* ---------- Assinatura ---------- */
.sign-wrap{text-align:center;}
.sign-canvas{border:2px dashed var(--gold-300);border-radius:var(--radius);background:#fff;width:100%;max-width:420px;
  height:180px;touch-action:none;cursor:crosshair;margin:0 auto 12px;display:block;}
.sign-hint{font-family:var(--font-ui);font-size:12px;color:var(--muted);margin-bottom:12px;}

/* ---------- Perfil do advogado (visível) ---------- */
.lawyer{display:flex;gap:22px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:26px;box-shadow:var(--shadow);max-width:520px;margin:0 auto;}
.lawyer .ph{width:84px;height:84px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--navy-700),var(--navy-900));
  display:flex;align-items:center;justify-content:center;color:var(--gold-300);font-family:var(--font-display);font-size:1.8rem;}
.lawyer .ph img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.lawyer .li h4{font-family:var(--font-display);font-size:1.3rem;color:var(--navy-800);}
.lawyer .li .oab{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--gold-600);margin:2px 0 6px;}
.lawyer .li p{font-size:.95rem;color:var(--slate);}

/* ---------- "O que o advogado verifica" ---------- */
.check-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:760px;margin:0 auto;}
.check-list li{list-style:none;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px 14px 44px;
  position:relative;font-size:.96rem;color:var(--ink);}
.check-list li::before{content:"✓";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;
  border-radius:50%;background:var(--gold-grad);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;}

/* ---------- Comparativo antes/depois ---------- */
.beforeafter{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:760px;margin:0 auto;}
.ba{border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border);}
.ba.before{background:#fff;}
.ba.after{background:linear-gradient(135deg,var(--navy-800),var(--navy-900));color:#fff;border-color:transparent;}
.ba h4{font-family:var(--font-ui);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:12px;}
.ba.before h4{color:var(--muted);}.ba.after h4{color:var(--gold-300);}
.ba ul{list-style:none;}
.ba li{padding:7px 0 7px 22px;position:relative;font-size:.95rem;}
.ba.before li::before{content:"–";position:absolute;left:0;color:var(--muted);}
.ba.after li::before{content:"✓";position:absolute;left:0;color:var(--gold-300);}
.ba.before li{color:var(--slate);}.ba.after li{color:#D7DEE8;}

/* ---------- Prova social / depoimentos ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.testi{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow);}
.testi .stars{color:var(--gold-500);font-size:14px;letter-spacing:2px;margin-bottom:10px;}
.testi p{font-size:.98rem;color:var(--ink);line-height:1.55;}
.testi .who{display:flex;align-items:center;gap:10px;margin-top:16px;}
.testi .who .av{width:38px;height:38px;border-radius:50%;background:var(--navy-50);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;color:var(--navy-700);}
.testi .who b{font-family:var(--font-ui);font-size:13px;color:var(--navy-800);display:block;}
.testi .who span{font-family:var(--font-ui);font-size:11px;color:var(--muted);}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto;}
.faq details{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;}
.faq summary{font-family:var(--font-ui);font-weight:600;font-size:1rem;color:var(--navy-800);padding:18px 22px;cursor:pointer;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-size:22px;color:var(--gold-600);font-weight:400;transition:.2s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq details p{padding:0 22px 20px;color:var(--slate);font-size:.97rem;line-height:1.6;}

/* ---------- Banner do quiz (home) ---------- */
.quiz-banner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  background:linear-gradient(135deg,var(--navy-800),var(--navy-900));border-radius:var(--radius-lg);
  padding:32px 38px;box-shadow:var(--shadow-lg);}
.quiz-banner h3{font-family:var(--font-display);font-size:1.5rem;color:#fff;line-height:1.15;}
.quiz-banner p{color:#D7DEE8;margin-top:6px;font-size:.98rem;max-width:520px;}
.quiz-banner .btn{flex-shrink:0;}

/* ---------- Quiz ---------- */
.quiz{max-width:620px;margin:0 auto;}
.quiz-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:38px;}
.quiz-progress{height:6px;background:var(--navy-50);border-radius:999px;overflow:hidden;margin-bottom:26px;}
.quiz-progress i{display:block;height:100%;background:var(--gold-grad);transition:width .3s var(--ease);}
.quiz-q{font-family:var(--font-display);font-size:1.5rem;color:var(--navy-800);margin-bottom:22px;line-height:1.2;}
.quiz-opts{display:flex;flex-direction:column;gap:10px;}
.quiz-opt{text-align:left;font-family:var(--font-ui);font-size:1rem;color:var(--ink);background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:16px 18px;cursor:pointer;transition:.18s var(--ease);display:flex;align-items:center;gap:12px;}
.quiz-opt:hover{border-color:var(--gold-500);transform:translateX(3px);box-shadow:var(--shadow);}
.quiz-opt .ic{width:34px;height:34px;border-radius:8px;background:var(--navy-50);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.quiz-result .doc-card{position:static;}

/* ---------- Verificação ---------- */
.verify-card{max-width:560px;margin:0 auto;text-align:center;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:40px 36px;}
.verify-icon{width:76px;height:76px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:34px;}
.verify-icon.ok{background:rgba(46,107,79,.12);color:var(--success);}
.verify-icon.warn{background:rgba(203,176,121,.15);color:var(--gold-600);}
.verify-icon.no{background:rgba(155,44,44,.1);color:var(--danger);}
.verify-card h1{font-family:var(--font-display);font-size:1.7rem;color:var(--navy-800);}
.verify-card .vrow{display:flex;justify-content:space-between;border-top:1px solid var(--border);padding:13px 0;
  font-family:var(--font-ui);font-size:14px;}
.verify-card .vrow span:first-child{color:var(--slate);}
.verify-card .vrow span:last-child{color:var(--navy-800);font-weight:600;}
.verify-form{display:flex;gap:8px;max-width:420px;margin:18px auto 0;}
.verify-form input{flex:1;font-family:var(--font-ui);letter-spacing:2px;text-transform:uppercase;padding:13px 14px;
  border:1px solid var(--border);border-radius:var(--radius);}

/* ---------- Painel do advogado ---------- */
.adv-tag{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  color:var(--gold-600);border:1px solid var(--gold-300);border-radius:999px;padding:6px 14px;}
.adv-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px;}
.adv-tab{font-family:var(--font-ui);font-size:13px;font-weight:600;border:1px solid var(--border);background:#fff;cursor:pointer;
  padding:9px 16px;border-radius:999px;color:var(--slate);transition:.18s var(--ease);}
.adv-tab:hover{border-color:var(--gold-500);}
.adv-tab.active{background:var(--navy-800);color:#fff;border-color:var(--navy-800);}

/* Modal de revisão com painel lateral */
.doc-modal .dm-inner:has(.dm-review){width:min(1040px,100%);}
.dm-review{display:grid;grid-template-columns:1fr 320px;gap:20px;align-items:start;}
.dm-sheet-col{min-width:0;}
.dm-side{background:#fff;border-radius:var(--radius-lg);padding:24px;position:sticky;top:0;}
.dm-side h3{font-family:var(--font-display);font-size:1.3rem;color:var(--navy-800);margin-bottom:12px;}
.dm-meta{font-family:var(--font-ui);font-size:13px;color:var(--slate);line-height:1.7;margin-bottom:18px;}
.dm-meta .code{color:var(--gold-600);letter-spacing:1px;}
.dm-label{display:block;font-family:var(--font-ui);font-size:12px;font-weight:500;color:var(--slate);margin-bottom:6px;}
.dm-side textarea{width:100%;min-height:120px;font-family:var(--font-ui);font-size:.95rem;padding:12px 13px;resize:vertical;
  border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;color:var(--ink);}
.dm-side textarea:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(203,176,121,.15);}
.dm-note{font-family:var(--font-ui);font-size:12px;color:var(--muted);margin-top:12px;line-height:1.5;}

/* ---------- Publicidade (interstitial de download) ---------- */
.ad-modal{position:fixed;inset:0;background:rgba(10,31,56,.74);backdrop-filter:blur(4px);z-index:200;
  display:none;align-items:center;justify-content:center;padding:20px;}
.ad-modal.open{display:flex;}
.ad-card{background:#fff;border-radius:var(--radius-lg);max-width:430px;width:100%;padding:24px;
  box-shadow:var(--shadow-lg);text-align:center;}
.ad-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.ad-lbl{font-family:var(--font-ui);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);
  border:1px solid var(--border);border-radius:4px;padding:2px 7px;}
.ad-prep{font-family:var(--font-ui);font-size:12px;color:var(--slate);}
.ad-slot{min-height:250px;display:flex;align-items:center;justify-content:center;background:var(--cream);
  border:1px dashed var(--border);border-radius:var(--radius);overflow:hidden;}
.ad-ph{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-family:var(--font-ui);padding:16px;}
.ad-ph span{font-size:14px;font-weight:600;}
.ad-ph small{font-size:11px;}
.ad-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px;}
.ad-timer{font-family:var(--font-ui);font-size:13px;color:var(--slate);}
.ad-note{font-family:var(--font-ui);font-size:11px;color:var(--muted);margin-top:12px;line-height:1.5;}

/* ---------- Selo "em breve" ---------- */
.soon{display:inline-block;font-family:var(--font-ui);font-size:9px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;background:rgba(14,42,71,.12);color:var(--navy-800);border-radius:999px;padding:3px 8px;margin-left:8px;vertical-align:middle;}

/* ---------- Consentimento de cookies/anúncios (LGPD) ---------- */
.cj-consent{position:fixed;left:16px;right:16px;bottom:16px;z-index:210;max-width:760px;margin:0 auto;
  background:var(--navy-900);color:#E6ECF4;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  padding:18px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-family:var(--font-ui);}
.cj-consent p{font-size:13px;line-height:1.55;flex:1;min-width:240px;color:#CBD5E4;}
.cj-consent a{color:var(--gold-300);text-decoration:underline;}
.cj-consent .cj-consent-actions{display:flex;gap:8px;flex-shrink:0;}

/* ---------- Faixa "Nossos serviços" (home) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:14px;}
.svc-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:30px;text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--gold-300);}
.svc-card.featured{background:linear-gradient(160deg,var(--navy-900),var(--navy-800));border-color:transparent;}
.svc-ic{width:54px;height:54px;border-radius:15px;background:var(--gold-grad);color:#fff;display:flex;
  align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0;}
.svc-ic svg{width:26px;height:26px;}
.svc-card h3{font-family:var(--font-display);font-size:1.3rem;color:var(--navy-800);margin-bottom:8px;}
.svc-card.featured h3{color:#fff;}
.svc-card p{color:var(--slate);line-height:1.55;flex:1;margin:0;}
.svc-card.featured p{color:#CBD5E4;}
.svc-link{margin-top:18px;font-family:var(--font-ui);font-weight:600;font-size:14px;color:var(--gold-600);}
.svc-card.featured .svc-link{color:var(--gold-500);}

/* ---------- Destaque de Cobrança na home ---------- */
.cob-promo{display:grid;grid-template-columns:1.3fr 1fr;gap:34px;align-items:center;
  background:linear-gradient(160deg,var(--navy-900),var(--navy-800));border-radius:var(--radius-lg);
  padding:40px;color:#fff;box-shadow:var(--shadow-lg);}
.cob-promo .kicker{color:var(--gold-500);}
.cob-promo-copy h2{font-family:var(--font-display);font-size:1.9rem;line-height:1.12;margin:8px 0 12px;color:#fff;}
.cob-promo-copy p{color:#CBD5E4;line-height:1.6;max-width:52ch;}
.cob-promo-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;}
.cob-promo-cta .btn-ghost{border-color:rgba(255,255,255,.4);color:#fff;}
.cob-promo-cta .btn-ghost:hover{background:rgba(255,255,255,.08);}
.cob-promo-list{list-style:none;display:flex;flex-direction:column;gap:12px;}
.cob-promo-list li{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  padding:14px 16px;display:flex;flex-direction:column;}
.cob-promo-list li b{font-family:var(--font-ui);color:var(--gold-500);font-size:13px;letter-spacing:.5px;text-transform:uppercase;}
.cob-promo-list li span{color:#CBD5E4;font-size:.95rem;margin-top:2px;}

/* ---------- Responsivo ---------- */
@media(max-width:880px){
  .dm-review{grid-template-columns:1fr;}
  .dm-side{position:static;}
  .cob-promo{grid-template-columns:1fr;padding:30px;}
}
@media(max-width:860px){
  .svc-grid{grid-template-columns:1fr;}
}
@media(max-width:760px){
  .check-list,.beforeafter,.testi-grid{grid-template-columns:1fr;}
  .pix-box{flex-direction:column;text-align:center;}
}
