:root{
  --ci-bg:#0b1020;
  --ci-surface:#ffffff;
  --ci-ink:#0f172a;
  --ci-muted:#64748b;
  --ci-line:#e6e8ef;
  --ci-primary:#4f46e5;     /* índigo */
  --ci-primary-600:#4338ca;
  --ci-primary-050:#eef2ff;
  --ci-accent:#f59e0b;      /* âmbar (destaque pontual) */
  --ci-ok:#16a34a;
  --ci-warn:#d97706;
  --ci-danger:#dc2626;
  --ci-radius:14px;
  --ci-shadow:0 1px 2px rgba(16,24,40,.04), 0 8px 24px rgba(16,24,40,.06);
}

*{box-sizing:border-box}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ci-ink);
  background:#f6f7fb;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,.display, .brand-mark{
  font-family:'Sora','Inter',system-ui,sans-serif;
  letter-spacing:-.01em;
}

a{color:var(--ci-primary);text-decoration:none}
a:hover{color:var(--ci-primary-600)}

/* ---------- Layout app ---------- */
.app-shell{display:flex;min-height:100vh}
.app-sidebar{
  width:248px;flex:0 0 248px;background:#0f1530;color:#cdd3e6;
  padding:22px 16px;position:sticky;top:0;height:100vh;
}
.app-main{flex:1;min-width:0;padding:26px clamp(16px,4vw,38px)}
.brand{display:flex;align-items:center;gap:10px;margin-bottom:26px;color:#fff}
.brand-logo{
  width:34px;height:34px;border-radius:9px;
  background:linear-gradient(135deg,var(--ci-primary),#7c75f0);
  display:grid;place-items:center;color:#fff;font-weight:700;font-family:'Sora',sans-serif;
}
.brand-name{font-weight:600;font-size:15px;line-height:1.1}
.nav-link-ci{
  display:flex;align-items:center;gap:11px;color:#aab2cf;
  padding:10px 12px;border-radius:10px;font-size:14.5px;margin-bottom:3px;
}
.nav-link-ci:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-link-ci.active{background:var(--ci-primary);color:#fff}
.nav-sep{height:1px;background:rgba(255,255,255,.08);margin:14px 4px}
/* Ícone dentro do brand */
.brand-logo svg{width:20px;height:20px;display:block}
/* Topbar mobile / overlay / botão menu — escondidos no desktop */
.app-topbar{display:none}
.app-overlay{display:none}
.app-menu-btn{display:none}

/* ---------- Cards ---------- */
.card-ci{
  background:var(--ci-surface);border:1px solid var(--ci-line);
  border-radius:var(--ci-radius);box-shadow:var(--ci-shadow);
}
.card-ci .card-body{padding:20px}
.muted{color:var(--ci-muted)}

/* saldo */
.saldo-card{
  background:linear-gradient(135deg,#1e1b4b,#4f46e5);color:#fff;border:none;
}
.saldo-num{font-family:'Sora',sans-serif;font-size:40px;font-weight:700;line-height:1}

/* atalhos */
.atalho{
  display:flex;gap:14px;align-items:flex-start;padding:18px;border-radius:var(--ci-radius);
  border:1px solid var(--ci-line);background:#fff;transition:.15s;height:100%;
}
.atalho:hover{border-color:var(--ci-primary);box-shadow:var(--ci-shadow);transform:translateY(-1px)}
.atalho .ico{
  width:42px;height:42px;border-radius:11px;flex:0 0 42px;display:grid;place-items:center;
  background:var(--ci-primary-050);color:var(--ci-primary);font-size:20px;
}

/* botões */
.btn-ci{
  background:var(--ci-primary);border:none;color:#fff;border-radius:10px;
  padding:11px 18px;font-weight:600;font-size:14.5px;
}
.btn-ci,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  text-decoration:none;cursor:pointer;line-height:1.25;text-align:center;
}
.btn-ci.w-100,.btn-ghost.w-100{display:flex}
.btn-ci:hover{background:var(--ci-primary-600);color:#fff}
.btn-ci:disabled{opacity:.65}
.btn-ghost{background:#fff;border:1px solid var(--ci-line);color:var(--ci-ink);border-radius:10px;padding:11px 18px;font-weight:600}
.btn-ghost:hover{border-color:var(--ci-primary);color:var(--ci-primary)}

/* badges status */
.badge-ci{font-size:12px;font-weight:600;border-radius:999px;padding:4px 10px}
.badge-gerado{background:#dcfce7;color:#166534}
.badge-rascunho{background:#fef9c3;color:#854d0e}
.badge-erro{background:#fee2e2;color:#991b1b}
.badge-modulo{background:var(--ci-primary-050);color:var(--ci-primary-600)}

/* tabela responsiva -> vira card no mobile */
.tabela-ci{width:100%;border-collapse:collapse}
.tabela-ci th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--ci-muted);text-align:left;padding:10px 12px}
.tabela-ci td{padding:13px 12px;border-top:1px solid var(--ci-line);font-size:14.5px;vertical-align:middle}

/* ---------- Auth ---------- */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-aside{
  background:linear-gradient(160deg,#0f1530 0%,#312e81 60%,#4f46e5 100%);
  color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:space-between;
}
.auth-aside h2{font-size:30px;line-height:1.18;max-width:24ch}
.auth-aside .feat{display:flex;gap:12px;align-items:flex-start;margin-top:16px;color:#dfe3f5}
.auth-aside .feat .dot{width:8px;height:8px;border-radius:50%;background:var(--ci-accent);margin-top:7px;flex:0 0 8px}
.auth-form{display:flex;align-items:center;justify-content:center;padding:40px 22px;background:#fff}
.auth-card{width:100%;max-width:400px}
.form-label{font-weight:600;font-size:13.5px;margin-bottom:6px}
.form-control,.form-select{
  border-radius:10px;border:1px solid var(--ci-line);padding:11px 13px;font-size:14.5px;
}
.form-control:focus,.form-select:focus{
  border-color:var(--ci-primary);box-shadow:0 0 0 3px var(--ci-primary-050);
}

/* alerta inline (feedback AJAX) */
.alert-inline{display:none;border-radius:10px;padding:11px 13px;font-size:14px;margin-bottom:6px}
.alert-inline.erro{display:block;background:#fee2e2;color:#991b1b}
.alert-inline.ok{display:block;background:#dcfce7;color:#166534}

/* dropzone logo */
.dropzone{
  border:1.5px dashed var(--ci-line);border-radius:12px;padding:22px;text-align:center;
  cursor:pointer;transition:.15s;background:#fafbff;
}
.dropzone:hover{border-color:var(--ci-primary);background:var(--ci-primary-050)}
.dropzone .preview{max-height:74px;border-radius:8px;margin-top:8px}

/* ---------- Mobile ---------- */
.topbar-mobile{display:none}
@media (max-width:991px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-aside{display:none}
}
@media (max-width:991px){
  /* Topbar fixa com botão de menu (hambúrguer) */
  .app-topbar{
    display:flex;align-items:center;gap:10px;
    position:sticky;top:0;z-index:1020;
    background:#0f1530;color:#fff;padding:10px 14px;overflow:hidden;
  }
  .app-topbar .brand{margin-bottom:0;color:#fff;min-width:0;flex:1 1 auto}
  .app-topbar .brand-logo{flex:0 0 32px;width:32px;height:32px}
  .app-topbar .brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:15px}
  .app-menu-btn{
    display:inline-flex;align-items:center;justify-content:center;
    width:42px;height:42px;flex:0 0 42px;border:0;border-radius:10px;
    background:rgba(255,255,255,.10);color:#fff;cursor:pointer;
  }
  .app-menu-btn svg{width:24px;height:24px}

  .app-shell{flex-direction:column}

  /* Sidebar vira gaveta (off-canvas) que desliza da esquerda */
  .app-sidebar{
    position:fixed;top:0;left:0;height:100vh;width:82%;max-width:300px;
    flex:none;transform:translateX(-100%);transition:transform .22s ease;
    z-index:1050;overflow-y:auto;box-shadow:0 0 50px rgba(0,0,0,.45);
    padding:18px 16px;
  }
  .app-sidebar.is-open{transform:translateX(0)}
  .app-sidebar .brand{margin-bottom:20px}
  .app-sidebar .brand-name{font-size:16px}
  .nav-link-ci{margin-bottom:5px;white-space:normal;padding:13px 14px;font-size:15.5px;color:#e2e7f7}
  .nav-link-ci:hover{background:rgba(255,255,255,.10);color:#fff}
  .nav-link-ci.active{background:var(--ci-primary);color:#fff;box-shadow:0 8px 20px rgba(79,70,229,.45)}

  /* Fundo escurecido atrás da gaveta */
  .app-overlay{
    display:block;position:fixed;inset:0;background:rgba(2,6,23,.5);
    z-index:1040;opacity:0;visibility:hidden;transition:opacity .2s ease, visibility .2s ease;
  }
  body.menu-open .app-overlay{opacity:1;visibility:visible}
  body.menu-open{overflow:hidden}

  .app-main{padding:18px 14px;overflow-x:hidden}
  .app-main h1.h4{font-size:1.15rem}
  .card-ci .card-body{padding:16px}
  .site-wrap{padding:0 16px}

  /* tabela vira cards */
  .tabela-ci thead{display:none}
  .tabela-ci, .tabela-ci tbody, .tabela-ci tr, .tabela-ci td{display:block;width:100%}
  .tabela-ci tr{border:1px solid var(--ci-line);border-radius:12px;margin-bottom:10px;padding:6px 4px}
  .tabela-ci td{border:none;padding:7px 12px}
  .tabela-ci td::before{content:attr(data-label);display:block;font-size:11px;text-transform:uppercase;color:var(--ci-muted);letter-spacing:.04em}

  /* números/cartões grandes encolhem um pouco */
  .saldo-num{font-size:32px}
  .pacote .creditos{font-size:30px}

  /* documento: tabela rola na horizontal em vez de estourar a tela */
  .doc-html{overflow-x:auto}
  .doc-text{padding:16px;font-size:14px}
  .doc-html table{display:block;width:100%;overflow-x:auto;white-space:nowrap}

  /* grids de cards do painel empilham confortável */
  .pacotes-grid{grid-template-columns:1fr}
}

/* Telas bem estreitas (celular pequeno) */
@media (max-width:480px){
  .app-main{padding:14px 12px}
  .saldo-num{font-size:28px}
  .btn-ci,.btn-ghost{padding:11px 14px}
  .esteira-step{min-width:64px}
  .esteira-step .lbl{font-size:10.5px}
}

/* ---------- Pacotes de crédito ---------- */
.pacotes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}
.pacote{position:relative;display:block;cursor:pointer;margin:0}
.pacote input{position:absolute;opacity:0;pointer-events:none}
.pacote .box{
  border:1.5px solid var(--ci-line);border-radius:var(--ci-radius);background:#fff;
  padding:20px;height:100%;transition:.15s;
}
.pacote:hover .box{border-color:var(--ci-primary)}
.pacote input:checked + .box{
  border-color:var(--ci-primary);box-shadow:0 0 0 3px var(--ci-primary-050);
}
.pacote .creditos{font-family:'Sora',sans-serif;font-size:34px;font-weight:700;line-height:1}
.pacote .preco{font-size:20px;font-weight:600;margin-top:6px}
.pacote .preco small{font-size:13px;color:var(--ci-muted);font-weight:500}
.pacote .selo{
  position:absolute;top:-10px;right:14px;background:var(--ci-accent);color:#3a2a02;
  font-size:11px;font-weight:700;border-radius:999px;padding:3px 10px;
}
.pacote .unit{color:var(--ci-muted);font-size:12.5px;margin-top:8px}

/* linha de extrato */
.mov-in{color:var(--ci-ok);font-weight:600}
.mov-out{color:var(--ci-danger);font-weight:600}

/* ---------- Prévia de documento ---------- */
.doc-text{
  white-space:pre-wrap;word-wrap:break-word;
  font-family:'Inter',system-ui,sans-serif;font-size:14.5px;line-height:1.7;color:#1f2937;
  background:#fafbff;border:1px solid var(--ci-line);border-radius:12px;padding:22px;
  max-height:70vh;overflow:auto;
}

/* ---------- Site público / landing ---------- */
.site-wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.site-header{background:#fff;border-bottom:1px solid var(--ci-line);padding:14px 0;position:sticky;top:0;z-index:10}
.hero{padding:64px 0 40px;background:radial-gradient(1200px 400px at 70% -10%, #eef2ff 0%, #f6f7fb 60%)}
.hero-tag{display:inline-block;background:var(--ci-primary-050);color:var(--ci-primary-600);font-weight:600;font-size:12.5px;border-radius:999px;padding:5px 12px;margin-bottom:14px}
.hero-title{font-family:'Sora',sans-serif;font-size:clamp(28px,5vw,46px);line-height:1.12;max-width:18ch;margin-bottom:14px}
.hero-sub{font-size:17px;color:var(--ci-muted);max-width:56ch;margin-bottom:22px}
.site-footer{background:#0f1530;color:#aab2cf;padding:26px 0;margin-top:30px}
.site-footer p{color:#cdd3e6}

/* rodapé de compliance dentro do app */
.app-footer{margin-top:32px;padding-top:16px;border-top:1px solid var(--ci-line);color:var(--ci-muted);font-size:12.5px}

/* ---------- Barra de progresso (gerações longas) ---------- */
.ci-progress-track{height:10px;border-radius:999px;background:var(--ci-line);overflow:hidden}
.ci-progress-bar{height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg, var(--ci-primary-600), var(--ci-primary));
  transition:width .25s ease}
.ci-progress-meta{display:flex;justify-content:space-between;align-items:center;
  margin-top:6px;font-size:13px;color:var(--ci-muted)}
.ci-progress-meta .ci-progress-pct{font-weight:600;color:var(--ci-primary-600)}

/* ---------- Prévia do relatório/contrato (HTML formatado) ---------- */
.doc-html{color:#2b2b2b;line-height:1.6;font-size:14.5px}
.doc-html h1,.doc-html h2,.doc-html h3{color:var(--ci-primary-600);line-height:1.25;margin:18px 0 8px}
.doc-html h1{font-size:20px}
.doc-html h2{font-size:17px;border-bottom:2px solid #e7e3d4;padding-bottom:4px}
.doc-html h2::after{content:"";display:block;width:54px;height:2px;background:#C2A24A;margin-top:4px}
.doc-html h3{font-size:15px}
.doc-html p{margin:8px 0}
.doc-html ul,.doc-html ol{margin:8px 0;padding-left:22px}
.doc-html li{margin:4px 0}
.doc-html strong{color:#1f2937}
.doc-html .cbx{color:var(--ci-primary-600);font-weight:700}
.doc-html table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13.5px}
.doc-html th{background:#0B1F3A;color:#fff;text-align:left;padding:8px 10px;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
.doc-html td{border:1px solid #e5e7eb;padding:7px 10px;vertical-align:top}
.doc-html tr:nth-child(even) td{background:#f7f7f9}
.doc-html hr{border:none;border-top:1px solid #eee;margin:16px 0}
.doc-html code{background:#f1f1f4;padding:1px 5px;border-radius:4px;font-size:13px}

/* ---------- Caixa "preencher pelo cadastro" ---------- */
.cad-box{background:var(--ci-primary-050);border:1px solid #e4e4f5;border-radius:12px;padding:14px 16px}

/* ---------- Esteira de estados do negócio ---------- */
.esteira{display:flex;gap:6px;flex-wrap:wrap;align-items:flex-start}
.esteira-step{flex:1 1 0;min-width:80px;text-align:center;position:relative}
.esteira-step .dot{display:block;width:16px;height:16px;border-radius:50%;margin:0 auto 6px;background:#d7d7e0;border:2px solid #d7d7e0}
.esteira-step .lbl{font-size:11.5px;color:#8a8a99;line-height:1.2;display:block}
.esteira-step.on .dot{background:var(--ci-primary-600);border-color:var(--ci-primary-600)}
.esteira-step.on .lbl{color:var(--ci-primary-600);font-weight:600}
.esteira-step:not(:last-child)::after{content:"";position:absolute;top:7px;left:50%;width:100%;height:2px;background:#e4e4ee;z-index:-1}
.esteira-step.on:not(:last-child)::after{background:var(--ci-primary-600)}
.badge-rascunho{background:#eef0f4;color:#555}

/* Barra de progresso (geração com IA) — segue a cor da marca */
.ci-progress{margin-top:14px;max-width:420px}
.ci-progress-track{height:12px;background:#eef1f6;border-radius:999px;overflow:hidden}
.ci-progress-fill{height:100%;width:0;border-radius:999px;background:var(--ci-primary);
  transition:width .25s ease;background-image:linear-gradient(90deg,var(--ci-primary),color-mix(in srgb,var(--ci-primary) 55%,#000))}
.ci-progress-label{font-size:13px;color:var(--ci-muted);margin-top:7px;font-variant-numeric:tabular-nums}
.ci-progress-pct{font-weight:700;color:var(--ci-primary)}

/* Badge do papel "Procurador" (lista de clientes) */
.badge-proc{background:#ede9fe;color:#5b21b6}

/* ---------- Responsividade geral (mobile) ---------- */
img{max-width:100%;height:auto}