:root{
  --bg:#f5f6fb; --surface:#ffffff; --ink:#1e2235; --muted:#6b7280;
  --line:#e8eaf2; --primary:#5b5bd6; --primary-700:#4848b8;
  --violet:#6d5dfc; --teal:#0ea5a5; --amber:#f59e0b; --rose:#f43f5e;
  --ok:#10b981; --erro:#ef4444;
  --shadow:0 10px 30px rgba(31,35,75,.08); --shadow-sm:0 2px 8px rgba(31,35,75,.06);
  --radius:16px;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
a{color:inherit;text-decoration:none}
h1{font-size:1.4rem;margin:0}h2{font-size:1.1rem;margin:0 0 .8rem}

/* ---------- layout ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{width:248px;background:linear-gradient(170deg,#2a2a55,#1c1c3a);color:#cfd2e6;
  display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 22px}
.brand strong{display:block;font-size:1.05rem;color:#fff}
.brand small{color:#9aa0c7}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,var(--violet),var(--teal));color:#fff;font-size:1rem;box-shadow:var(--shadow-sm)}
.brand-mark.big{width:60px;height:60px;font-size:1.6rem;margin:0 auto 14px}
.nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:11px;color:#c4c8e6;font-weight:500;transition:.18s}
.nav a span{font-size:1.05rem}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav a.active{background:linear-gradient(135deg,var(--violet),var(--primary));color:#fff;box-shadow:var(--shadow-sm)}
.sidebar-foot{display:flex;align-items:center;gap:10px;padding:12px 8px 0;border-top:1px solid rgba(255,255,255,.08);margin-top:10px}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--violet));
  color:#fff;display:grid;place-items:center;font-weight:700}
.who{flex:1;min-width:0}.who strong{display:block;color:#fff;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who small{color:#9aa0c7}
.sair{font-size:1.2rem;color:#9aa0c7;padding:6px}.sair:hover{color:#fff}

.content{flex:1;padding:26px 34px;max-width:1180px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.topbar-right{display:flex;gap:10px}

/* ---------- cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px;margin-bottom:24px}
.card{background:var(--surface);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;
  box-shadow:var(--shadow);transition:.2s;border:1px solid var(--line)}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(31,35,75,.13)}
.card-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;color:#fff}
.card.violet .card-icon{background:linear-gradient(135deg,#6d5dfc,#8b7bff)}
.card.teal .card-icon{background:linear-gradient(135deg,#0ea5a5,#34d3c3)}
.card.amber .card-icon{background:linear-gradient(135deg,#f59e0b,#fbbf24)}
.card.rose .card-icon{background:linear-gradient(135deg,#f43f5e,#fb7185)}
.card-valor{font-size:1.7rem;font-weight:800;display:block;line-height:1.1}
.card-titulo{color:var(--muted);font-size:.85rem}

/* ---------- panel / tabela ---------- */
.panel{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--line);margin-bottom:20px}
.panel.center{text-align:center;padding:48px}
.muted{color:var(--muted)}
.hint{margin-top:16px;padding:13px 16px;border-radius:12px;background:#eef0fe;color:#3b3b8f;font-size:.9rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:820px){.grid-2{grid-template-columns:1fr}}

.tabela{width:100%;border-collapse:collapse}
.tabela th{text-align:left;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:0 12px 12px}
.tabela td{padding:14px 12px;border-top:1px solid var(--line);vertical-align:middle}
.acoes{text-align:right;white-space:nowrap}
.inline{display:inline}

.badge{display:inline-block;padding:4px 11px;border-radius:999px;font-size:.78rem;font-weight:600}
.cargo-presidente{background:#ede9fe;color:#6d28d9}
.cargo-diretor{background:#e0f2fe;color:#0369a1}
.cargo-consultor{background:#dcfce7;color:#15803d}
.cargo-assistente{background:#fef3c7;color:#b45309}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
.dot.ok{background:var(--ok)}.dot.off{background:#cbd5e1}

/* ---------- forms / botões ---------- */
.form{display:flex;flex-direction:column;gap:14px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:#3a3f57}
.form input,.form select{padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;font-size:.95rem;font-family:inherit;background:#fbfbfe;transition:.15s}
.form input:focus,.form select:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(91,91,214,.12)}
.check{flex-direction:row;align-items:center;gap:8px;font-weight:500}
.senha-wrap{position:relative;display:flex}
.senha-wrap input{flex:1;padding-right:42px}
.toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6}
.toggle:hover{opacity:1}
.btn{padding:10px 18px;border-radius:11px;border:1.5px solid var(--line);background:#fff;font-weight:600;font-size:.92rem;cursor:pointer;font-family:inherit;transition:.15s}
.btn:hover{background:#f3f4fb}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--violet));color:#fff;border:none;box-shadow:var(--shadow-sm)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-block{width:100%;padding:12px}
.icon-btn{background:none;border:none;cursor:pointer;font-size:1.05rem;padding:6px;border-radius:8px}
.icon-btn:hover{background:#f0f1f8}.icon-btn.danger:hover{background:#fee2e2}
.dados{display:grid;grid-template-columns:120px 1fr;gap:10px 16px;margin:0}
.dados dt{color:var(--muted);font-size:.85rem}.dados dd{margin:0;font-weight:500}

/* ---------- flash ---------- */
.flash{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 18px;border-radius:12px;margin-bottom:18px;font-weight:500;animation:slideDown .3s}
.flash.ok{background:#dcfce7;color:#15803d}.flash.erro{background:#fee2e2;color:#b91c1c}
.flash button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:inherit;opacity:.7}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;background:rgba(20,22,45,.5);backdrop-filter:blur(3px);
  display:none;place-items:center;z-index:50;padding:20px;animation:fade .2s}
.modal.open{display:grid}
.modal-card{background:#fff;border-radius:18px;padding:28px;width:100%;max-width:440px;box-shadow:0 24px 60px rgba(0,0,0,.25);animation:pop .22s}
.modal-card h3{margin:0 0 18px}
.modal-acoes{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}
.big-emoji{font-size:3rem;margin-bottom:10px}

/* ---------- financeiro ---------- */
.meta-linha{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.scroll-x{overflow-x:auto}
.tabela.compacta th,.tabela.compacta td{padding:8px 10px;font-size:.82rem;white-space:nowrap}
.tabela .num{text-align:right;font-variant-numeric:tabular-nums}
.tabela .forte{font-weight:600}
.tabela .zero{color:#c2c6d2}
.tabela .neg{color:var(--erro);font-weight:600}
.sticky-col{position:sticky;left:0;background:var(--surface);z-index:1;text-align:left!important;min-width:210px}
.tabela tfoot td{border-top:2px solid var(--line);background:#fafbff}
.alerta-row{display:grid;grid-template-columns:90px 1fr 120px;align-items:center;gap:14px;padding:12px 6px;border-top:1px solid var(--line)}
.alerta-row:first-child{border-top:none}
.alerta-tag{font-weight:700;font-size:.85rem;padding:5px 8px;border-radius:8px;text-align:center}
.alerta-tag.critico{background:#fee2e2;color:#b91c1c}
.alerta-tag.aviso{background:#fef3c7;color:#b45309}
.alerta-info{display:flex;flex-direction:column}
.alerta-info strong{font-size:.95rem}
.alerta-bar{height:8px;background:#eef0f6;border-radius:99px;overflow:hidden}
.alerta-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--amber),var(--rose))}

.barras{display:flex;flex-direction:column;gap:11px}
.barra-row{display:grid;grid-template-columns:130px 1fr 48px;align-items:center;gap:10px}
.barra-label{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.barra-trilho{height:16px;background:#eef0f6;border-radius:99px;overflow:hidden}
.barra-trilho span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--violet),var(--teal))}
.barra-val{font-size:.82rem;font-weight:600;text-align:right;color:var(--muted)}
.fluxo-row{display:grid;grid-template-columns:64px 1fr;align-items:center;gap:10px;margin-bottom:9px}
.fluxo-bars{display:flex;flex-direction:column;gap:3px}
.fluxo-trilho{height:11px;background:#eef0f6;border-radius:99px;overflow:hidden}
.fluxo-in{display:block;height:100%;background:var(--teal);border-radius:99px}
.fluxo-out{display:block;height:100%;background:var(--rose);border-radius:99px}
.legenda{font-size:.82rem;color:var(--muted);margin-top:10px;display:flex;align-items:center;gap:6px}
.dot-in,.dot-out{display:inline-block;width:10px;height:10px;border-radius:50%}
.dot-in{background:var(--teal)}.dot-out{background:var(--rose)}
.pe-escala{margin:6px 0 4px}
.pe-bar{position:relative;height:26px;background:linear-gradient(90deg,#dcfce7,#fef3c7 60%,#fee2e2);border-radius:99px;overflow:visible}
.pe-fill-oper{position:absolute;left:0;top:0;height:100%;background:rgba(91,91,214,.18);border-right:2px dashed var(--primary);border-radius:99px 0 0 99px}
.pe-marca{position:absolute;top:-4px;width:3px;height:34px;background:var(--rose);border-radius:2px}
.pe-legenda{display:flex;flex-direction:column;gap:3px;margin-top:12px;font-size:.85rem;color:var(--muted)}
.check-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:9px}
.check-list li{line-height:1.45}
.tabela .ok2{color:var(--ok);font-weight:600}
.big-num{font-size:2rem;font-weight:800;margin:.2rem 0 1rem;line-height:1.1}
.big-num small{display:block;font-size:.95rem;font-weight:500;color:var(--rose)}
.fat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;margin-bottom:16px}
@media(max-width:520px){.fat-grid{grid-template-columns:1fr}}

/* ---------- login ---------- */
.login-bg{min-height:100vh;display:grid;place-items:center;
  background:linear-gradient(135deg,#4b4bc4,#6d5dfc 50%,#0ea5a5)}
.login-card{background:#fff;border-radius:22px;padding:40px 36px;width:100%;max-width:400px;box-shadow:0 30px 70px rgba(0,0,0,.3);margin:20px}
.login-brand{text-align:center;margin-bottom:22px}
.login-brand h1{font-size:1.5rem;margin:4px 0 2px}
.login-brand p{color:var(--muted);margin:0}
.login-foot{text-align:center;color:var(--muted);font-size:.82rem;margin:18px 0 0}
/* parceiros: ficha (grid) + adicionar (linha) + área de e-mail */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid label{display:flex;flex-direction:column;gap:5px;font-size:.82rem;color:var(--muted)}
.form-grid .full{grid-column:1 / -1}
.form-inline{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:14px}
.form-inline input,.form-inline select{padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.9rem;background:#fbfbfe}
.form-inline input{flex:1;min-width:140px}
.email-area{width:100%;box-sizing:border-box;padding:14px;border:1.5px solid var(--line);border-radius:12px;
  font-family:'Inter',monospace;font-size:.9rem;line-height:1.55;background:#fbfbfe;resize:vertical}
@media(max-width:720px){.form-grid{grid-template-columns:1fr}}

/* faixa secundária de cards (atalhos no painel) — mais discreta */
.cards-sec{margin-top:-6px}
.cards-sec .card{padding:14px 18px;box-shadow:var(--shadow-sm)}
.cards-sec .card-valor{font-size:1.25rem}

/* ---------- Analista IA ---------- */
.ia-texto{font-size:.96rem;line-height:1.65}
.ia-texto h2{font-size:1.12rem;margin:18px 0 8px}
.ia-texto h3{font-size:1rem;margin:16px 0 6px}
.ia-texto h4{font-size:.92rem;margin:14px 0 4px;color:var(--muted)}
.ia-texto p{margin:8px 0}
.ia-texto ul,.ia-texto ol{margin:8px 0;padding-left:22px}
.ia-texto li{margin:5px 0}
.ia-texto strong{color:var(--primary-700)}
.ia-texto code{background:#eef0fe;padding:1px 6px;border-radius:6px;font-size:.85em}
.ia-form{display:flex;gap:10px;margin-top:6px;align-items:flex-end}
.ia-form textarea{flex:1;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:.95rem;background:#fbfbfe;resize:vertical;transition:.15s}
.ia-form textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(91,91,214,.12)}
.ia-resumo{max-height:230px;overflow:hidden;position:relative}
.ia-resumo::after{content:"";position:absolute;left:0;right:0;bottom:0;height:64px;background:linear-gradient(transparent,var(--surface))}
.ia-resposta{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.ia-pergunta{color:var(--muted);font-style:italic;margin:0 0 10px}

@media(max-width:720px){.sidebar{width:74px}.brand div,.who,.nav a span+*,.nav a:not(.active){}.content{padding:18px}}
