/* ═══ SANCTUM — design system (marca Stefani, dark premium quente) ═══ */
@font-face{font-family:'Fraunces';src:url('/fonts/fraunces.woff2') format('woff2');font-weight:300 700;font-display:swap;font-style:normal}
@font-face{font-family:'InterS';src:url('/fonts/inter.woff2') format('woff2');font-weight:300 700;font-display:swap;font-style:normal}
:root{
  --bg-0:#0D0B0C; --bg-1:#121012; --surf-1:#1A1618; --surf-2:#211C1F; --surf-3:#2A2327;
  --gold:#C9A96E; --gold-soft:rgba(201,169,110,.14); --gold-line:rgba(201,169,110,.22);
  --terra:#C46B3A; --ink:#F5F0EA; --mute:#9A928B; --faint:rgba(245,240,234,.45);
  --line:rgba(245,240,234,.08); --ok:#5C7A5C; --err:#C0553F;
  --serif:'Fraunces',Georgia,serif; --sans:'InterS',system-ui,-apple-system,'Segoe UI',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg-0);color:var(--ink);font-family:var(--sans);font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--gold);text-decoration:none}
button{font-family:inherit;cursor:pointer}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}

/* ── LOGIN split-screen ── */
.split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.pane-form{display:flex;align-items:center;justify-content:center;padding:clamp(28px,5vw,72px);background:var(--bg-1)}
.pane-brand{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 78% 12%,rgba(196,107,58,.16),transparent 46%),
  radial-gradient(100% 80% at 20% 92%,rgba(201,169,110,.10),transparent 50%),var(--bg-0);
  border-left:1px solid var(--line)}
.form-wrap{width:100%;max-width:380px;animation:rise .8s var(--ease) both}
.brand-mark{font-family:var(--serif);font-weight:300;letter-spacing:.02em;font-size:15px;color:var(--gold);
  display:flex;align-items:center;gap:10px;margin-bottom:40px}
.brand-mark i{width:22px;height:22px;border:1.5px solid var(--gold);border-radius:6px;display:inline-block;position:relative}
.brand-mark i::after{content:'';position:absolute;inset:5px;border-top:1.5px solid var(--gold);border-right:1.5px solid var(--gold);transform:rotate(45deg)}
h1.titulo{font-family:var(--serif);font-weight:300;font-size:clamp(30px,3.4vw,42px);line-height:1.05;margin:0 0 6px}
.sub{color:var(--mute);font-size:14px;margin:0 0 30px}
label{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:18px 0 8px}
.field{position:relative}
input[type=email],input[type=password],input[type=text].code{width:100%;padding:14px 16px;border-radius:11px;
  background:var(--surf-1);border:1px solid var(--line);color:var(--ink);font-size:15px;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
input:focus{outline:none;border-color:var(--gold-line);box-shadow:0 0 0 3px var(--gold-soft)}
input::placeholder{color:var(--faint)}
.btn{width:100%;margin-top:26px;padding:15px;border:none;border-radius:11px;background:var(--gold);color:#1a130a;
  font-size:14px;font-weight:600;letter-spacing:.02em;transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .3s var(--ease);
  box-shadow:0 10px 30px -12px rgba(201,169,110,.5)}
.btn:hover{background:#d8bd85;transform:translateY(-1px)}
.btn:disabled{opacity:.55;transform:none;cursor:default}
.linkrow{display:flex;justify-content:space-between;margin-top:16px;font-size:13px;color:var(--mute)}
.msg{margin-top:18px;padding:11px 14px;border-radius:10px;font-size:13.5px;display:none}
.msg.err{display:block;background:rgba(192,85,63,.12);border:1px solid rgba(192,85,63,.3);color:#e2a08f}
.msg.ok{display:block;background:rgba(92,122,92,.12);border:1px solid rgba(92,122,92,.3);color:#a8c0a8}
/* painel de marca */
.brand-inner{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:clamp(40px,5vw,80px)}
.brand-logo{font-family:var(--serif);font-weight:300;font-size:clamp(44px,6vw,84px);line-height:.98;letter-spacing:-.01em}
.brand-logo b{color:var(--gold);font-weight:400}
.brand-sig{color:var(--mute);font-size:14px;letter-spacing:.28em;text-transform:uppercase;margin-top:14px}
.brand-phrase{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(18px,1.7vw,23px);color:var(--faint);margin-top:44px;max-width:34ch;line-height:1.5}
.brand-glow{position:absolute;top:-20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(201,169,110,.12),transparent 60%);filter:blur(30px);pointer-events:none}
/* MFA */
.qr-box{background:#fff;border-radius:14px;padding:14px;width:200px;margin:6px 0 14px;box-shadow:0 12px 40px -16px rgba(0,0,0,.7)}
.qr-box svg{width:100%;height:auto;display:block}
.code{letter-spacing:.5em;text-align:center;font-size:22px!important}
.hidden{display:none!important}

/* ── COCKPIT shell ── */
.cockpit{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{background:var(--bg-1);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 16px}
.side .brand-mark{margin-bottom:34px;padding-left:6px}
.nav a{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:11px;color:var(--mute);font-size:14.5px;
  margin-bottom:4px;transition:background .2s var(--ease),color .2s var(--ease)}
.nav a svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.7;flex:none}
.nav a:hover{background:var(--surf-1);color:var(--ink)}
.nav a.on{background:var(--gold-soft);color:var(--gold)}
.side-foot{margin-top:auto;display:flex;align-items:center;gap:11px;padding:12px 8px;border-top:1px solid var(--line)}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--terra));display:flex;align-items:center;justify-content:center;color:#1a130a;font-weight:600;font-size:15px;flex:none}
.side-foot .nm{font-size:13.5px;line-height:1.3}.side-foot .rl{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.1em}
.main{padding:clamp(24px,3vw,40px);display:flex;flex-direction:column;gap:26px;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px}
.greet h2{font-family:var(--serif);font-weight:300;font-size:clamp(24px,2.6vw,34px);margin:0}
.greet p{color:var(--mute);font-size:13.5px;margin:4px 0 0}
.sesspill{display:flex;align-items:center;gap:9px;background:var(--surf-1);border:1px solid var(--line);padding:9px 15px;border-radius:30px;font-size:13px;color:var(--mute)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(92,122,92,.2)}
.ghost{background:var(--surf-1);border:1px solid var(--line);color:var(--mute);padding:9px 15px;border-radius:10px;font-size:13px;transition:color .2s,border-color .2s}
.ghost:hover{color:var(--ink);border-color:var(--gold-line)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--surf-1);border:1px solid var(--line);border-radius:16px;padding:20px;position:relative;overflow:hidden;
  animation:rise .7s var(--ease) both}
.card:nth-child(2){animation-delay:.06s}.card:nth-child(3){animation-delay:.12s}.card:nth-child(4){animation-delay:.18s}
.card .ic{width:38px;height:38px;border-radius:11px;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card .ic svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.7}
.card .lbl{color:var(--mute);font-size:13px}
.card .val{font-family:var(--serif);font-weight:300;font-size:34px;margin-top:2px;letter-spacing:-.01em}
.card .spark{position:absolute;right:16px;bottom:16px;opacity:.5}
.stage{flex:1;min-height:340px;border:1px solid var(--gold-line);border-radius:20px;position:relative;overflow:hidden;
  background:radial-gradient(90% 80% at 50% 25%,var(--surf-2),var(--bg-1));display:flex;align-items:center;justify-content:center;
  animation:rise .8s var(--ease) both;animation-delay:.24s}
.stage::before{content:'';position:absolute;inset:0;background-image:radial-gradient(var(--gold-soft) 1px,transparent 1px);background-size:26px 26px;opacity:.35;mask:radial-gradient(60% 60% at 50% 45%,#000,transparent)}
.stage-in{position:relative;text-align:center;color:var(--faint)}
.stage-in .ring{width:74px;height:74px;border-radius:50%;border:1.5px solid var(--gold-line);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;animation:pulse 3.5s var(--ease) infinite}
.stage-in .ring svg{width:30px;height:30px;stroke:var(--gold);fill:none;stroke-width:1.4}
.stage-in h3{font-family:var(--serif);font-weight:300;font-size:22px;color:var(--ink);margin:0 0 6px}
.stage-in p{font-size:13.5px;margin:0;max-width:36ch}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 var(--gold-soft)}50%{box-shadow:0 0 0 12px transparent}}

/* ── ESCRITÓRIO ISOMÉTRICO (Fatia 2) ── */
.stage-iso{padding:0;min-height:440px;align-items:stretch}
#escritorio{position:absolute;inset:0}
#escritorio canvas{display:block}
#iso-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--faint);font-size:13.5px;letter-spacing:.02em}
#iso-loading .ldot{width:9px;height:9px;border-radius:50%;background:var(--gold);animation:pulse 1.6s var(--ease) infinite}
#escritorio-labels{position:absolute;inset:0;pointer-events:none;overflow:hidden}
/* labels dos agentes: pill discreto ancorado no posto; papel revela no hover */
.iso-label{position:absolute;top:0;left:0;display:inline-flex;align-items:center;gap:7px;
  background:rgba(18,16,18,.55);backdrop-filter:blur(5px);pointer-events:auto;cursor:default;
  border:1px solid var(--gold-line);border-radius:20px;padding:4px 11px 4px 9px;white-space:nowrap;
  box-shadow:0 6px 18px -12px rgba(0,0,0,.7);
  transition:opacity .3s var(--ease),background .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease)}
/* haste fina ligando o pill ao posto abaixo */
.iso-label::after{content:'';position:absolute;left:50%;top:100%;width:1px;height:15px;transform:translateX(-50%);
  background:linear-gradient(var(--gold-line),transparent);pointer-events:none}
.iso-label .st{position:static;width:7px;height:7px;border-radius:50%;flex:none}
.iso-label .nm{font-family:var(--serif);font-size:12.5px;color:var(--ink);line-height:1;letter-spacing:.01em}
.iso-label .pp{font-size:10px;color:var(--faint);letter-spacing:.02em;max-width:0;opacity:0;overflow:hidden;
  transition:max-width .32s var(--ease),opacity .22s var(--ease),margin .32s var(--ease)}
/* hover: realca este pill acima dos outros e revela o papel */
.iso-label:hover{background:rgba(20,17,19,.92);border-color:var(--gold);z-index:6;box-shadow:0 14px 32px -14px rgba(0,0,0,.9)}
.iso-label:hover .pp{max-width:260px;opacity:1;margin-left:3px}
.st-ativo{background:var(--gold);box-shadow:0 0 0 3px rgba(201,169,110,.2)}
.st-trabalhando{background:#8fbf8f;box-shadow:0 0 0 3px rgba(143,191,143,.2)}
.st-ocioso{background:#6b6560}
.st-atencao{background:var(--terra);box-shadow:0 0 0 3px rgba(196,107,58,.25)}
.iso-title{position:absolute;top:18px;left:20px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);z-index:2}
.iso-title span{color:var(--gold)}
.iso-legend{position:absolute;bottom:16px;right:18px;display:flex;gap:16px;font-size:11.5px;color:var(--mute);z-index:2}
.iso-legend span{display:flex;align-items:center;gap:7px}
.iso-legend i{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ── CAMPO DE COMANDO (Fatia 3) ── */
.cmdbar{display:flex;align-items:center;gap:12px;background:var(--surf-1);border:1px solid var(--line);
  border-radius:14px;padding:6px 6px 6px 18px;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.cmdbar:focus-within{border-color:var(--gold-line);box-shadow:0 0 0 3px var(--gold-soft)}
.cmd-caret{color:var(--gold);font-family:var(--serif);font-size:20px;line-height:1}
#cmd-input{flex:1;background:none;border:none;color:var(--ink);font-size:15px;padding:12px 0;font-family:var(--sans)}
#cmd-input:focus{outline:none}#cmd-input::placeholder{color:var(--faint)}
#cmd-send{width:44px;height:44px;border:none;border-radius:10px;background:var(--gold);color:#1a130a;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s var(--ease)}
#cmd-send:hover{background:#d8bd85;transform:translateX(1px)}
/* log ao vivo */
#log-vivo{position:absolute;bottom:14px;left:16px;width:min(380px,44%);max-height:44%;z-index:3;
  background:rgba(15,13,16,.88);backdrop-filter:blur(8px);border:1px solid var(--gold-line);border-radius:13px;overflow:hidden;
  display:flex;flex-direction:column;animation:rise .4s var(--ease) both}
.log-head{display:flex;align-items:center;gap:9px;padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px}
.log-head b{flex:1;font-weight:500;color:var(--ink)}
#log-x{background:none;border:none;color:var(--faint);font-size:18px;line-height:1}#log-x:hover{color:var(--ink)}
#log-body{overflow-y:auto;padding:8px 14px 12px}
.log-line{font-size:12.5px;color:var(--mute);padding:5px 0 5px 14px;position:relative;line-height:1.4;border-left:1px solid var(--line);margin-left:3px}
.log-line::before{content:'';position:absolute;left:-4px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--faint)}
.log-line.a::before{background:var(--gold)}.log-line.w::before{background:#8fbf8f}
.log-line.ok{color:#a8c0a8}.log-line.ok::before{background:#8fbf8f;box-shadow:0 0 8px #8fbf8f}
.log-line.err{color:#e2a08f}.log-line.err::before{background:var(--terra)}
/* modal de confirmação */
.modal{position:fixed;inset:0;background:rgba(8,7,8,.72);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;animation:rise .25s var(--ease)}
.modal-in{background:var(--surf-2);border:1px solid var(--gold-line);border-radius:18px;padding:30px;max-width:460px;box-shadow:0 30px 80px -30px rgba(0,0,0,.9)}
.modal-in h3{font-family:var(--serif);font-weight:300;font-size:24px;margin:0 0 14px}
#confirm-txt{color:var(--ink);font-size:15px;font-style:italic;background:var(--surf-1);border-radius:10px;padding:12px 14px;border-left:2px solid var(--gold)}
.modal-note{color:var(--mute);font-size:13px;line-height:1.5;margin:16px 0 22px}
.modal-btns{display:flex;justify-content:flex-end;gap:12px}

@media (max-width:880px){.split{grid-template-columns:1fr}.pane-brand{display:none}
  .cockpit{grid-template-columns:1fr}.side{display:none}.cards{grid-template-columns:repeat(2,1fr)}}

/* ── SEÇÃO PROJETOS (visibilidade da operação) ─────────────────────────── */
#view-projetos{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0;animation:rise .5s var(--ease) both}
.pj-head{display:flex;align-items:baseline;gap:14px}
.pj-head h3{font-family:var(--serif);font-weight:300;font-size:26px;margin:0;color:var(--ink)}
.pj-head span{font-size:13px;color:var(--faint)}
.pj-head .ghost{margin-left:auto}
#pj-lista{display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0;padding-right:2px}

/* linha de projeto */
.pj-row{display:grid;grid-template-columns:118px minmax(0,1fr) auto;align-items:center;gap:16px;
  background:var(--surf-1);border:1px solid var(--line);border-radius:14px;padding:14px 18px;
  cursor:pointer;transition:border-color .2s var(--ease),background .2s var(--ease)}
.pj-row:hover,.pj-row:focus-visible{border-color:var(--gold-line);background:var(--surf-2);outline:none}
.pj-row:focus-visible{box-shadow:0 0 0 3px var(--gold-soft)}
.pj-row[aria-expanded="true"]{border-color:var(--gold-line);border-bottom-left-radius:0;border-bottom-right-radius:0}
.pj-tit{font-size:14px;color:var(--ink);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.pj-sub{font-size:11px;color:var(--faint);margin-top:3px;font-family:ui-monospace,Consolas,monospace;letter-spacing:.02em}
.pj-meta{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.pj-pill{font-size:11.5px;color:var(--mute);background:var(--bg-1);border:1px solid var(--line);
  border-radius:20px;padding:4px 10px;white-space:nowrap;font-variant-numeric:tabular-nums}

/* chip de status (cor + texto — nunca só cor) */
.pj-chip{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.04em;white-space:nowrap}
.pj-chip .pj-dot{width:8px;height:8px;border-radius:50%;flex:none}
.pj-chip.ok{color:#8fbf8f}.pj-chip.ok .pj-dot{background:#8fbf8f}
.pj-chip.err{color:var(--terra)}.pj-chip.err .pj-dot{background:var(--terra)}
.pj-chip.fila{color:var(--mute)}.pj-chip.fila .pj-dot{background:var(--mute)}
.pj-chip.run{color:var(--gold)}.pj-chip.run .pj-dot{background:var(--gold);animation:pulse 1.6s var(--ease) infinite}

/* detalhe expansível */
.pj-det{background:var(--bg-1);border:1px solid var(--gold-line);border-top:none;
  border-radius:0 0 14px 14px;padding:18px 20px;animation:rise .3s var(--ease) both}
.pj-etapa{margin:0 0 4px;font-size:13px;color:var(--mute)}
.pj-etapa.st-run{color:var(--gold)}.pj-etapa.st-ok{color:#8fbf8f}.pj-etapa.st-err{color:var(--terra)}
.pj-h{margin:16px 0 8px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-weight:500}
.pj-plano{font-size:13px;line-height:1.65;color:var(--mute);white-space:pre-wrap;max-height:210px;overflow-y:auto;
  background:var(--surf-1);border:1px solid var(--line);border-radius:10px;padding:14px 16px}

/* timeline T1→Tn */
.pj-tl{list-style:none;margin:0;padding:0;position:relative}
.pj-tl::before{content:'';position:absolute;left:13px;top:10px;bottom:10px;width:1px;
  background:linear-gradient(var(--gold-line),transparent)}
.pj-tl-item{display:flex;gap:14px;padding:8px 0;position:relative}
.pj-no{width:27px;height:27px;border-radius:50%;background:var(--surf-1);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;flex:none;z-index:1}
.pj-no svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pj-tl-item.ok .pj-no{color:#8fbf8f;border-color:rgba(143,191,143,.4)}
.pj-tl-item.err .pj-no{color:var(--terra);border-color:rgba(196,107,58,.45)}
.pj-tl-item.fila .pj-no{color:var(--mute)}
.pj-tl-item.run .pj-no{color:var(--gold);border-color:var(--gold);animation:pulse 1.6s var(--ease) infinite}
.pj-tl-item.run .pj-no svg{fill:currentColor;stroke:none}
.pj-tl-item.run .pj-tl-t{color:var(--gold)}
.pj-tl-t{font-size:13px;color:var(--ink)}.pj-tl-t b{font-weight:600;color:inherit}
.pj-tl-s{font-size:12.5px;color:var(--mute);margin-top:2px;line-height:1.45}
.pj-tl-ref{font-size:10.5px;color:var(--faint);margin-top:3px;font-family:ui-monospace,Consolas,monospace}

/* esqueleto / vazio */
.pj-skel{height:64px;border-radius:14px;border:1px solid var(--line);
  background:linear-gradient(100deg,var(--surf-1) 40%,var(--surf-2) 50%,var(--surf-1) 60%);
  background-size:200% 100%;animation:pj-shimmer 1.4s linear infinite}
@keyframes pj-shimmer{to{background-position:-200% 0}}
.pj-vazio{text-align:center;padding:56px 20px;color:var(--faint);border:1px dashed var(--line);border-radius:14px}
.pj-vazio h4{font-family:var(--serif);font-weight:300;font-size:20px;color:var(--ink);margin:0 0 8px}
.pj-vazio p{font-size:13.5px;margin:0 auto 14px;max-width:46ch;line-height:1.6}

/* responsivo + movimento reduzido */
@media (max-width:760px){
  .pj-row{grid-template-columns:1fr;gap:8px}
  .pj-meta{justify-content:flex-start}
}
@media (prefers-reduced-motion:reduce){
  #view-projetos,.pj-det{animation:none}
  .pj-skel,.pj-chip.run .pj-dot,.pj-tl-item.run .pj-no{animation:none}
}

/* ── SEÇÃO ANALYTICS (visão analítica) ─────────────────────────────────── */
#view-analytics{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0;animation:rise .5s var(--ease) both}
#an-corpo{display:flex;flex-direction:column;gap:16px;overflow-y:auto;min-height:0;padding-right:2px}
.an-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.an-card .val{font-variant-numeric:tabular-nums}
.an-sub{font-size:11.5px;color:var(--faint);margin-top:4px}
.an-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.an-fig{background:var(--surf-1);border:1px solid var(--line);border-radius:16px;padding:16px 18px;margin:0;min-width:0}
.an-fig h4{margin:0 0 10px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-weight:500}
.an-svg{width:100%;height:auto;display:block}
.an-svg .an-grid{stroke:var(--line)}
.an-svg .an-eixo{stroke:var(--gold-line)}
.an-svg text{font-family:var(--sans)}
.an-svg .an-ax{fill:var(--faint);font-size:10px}
.an-svg .an-val{fill:var(--ink);font-size:11px;font-variant-numeric:tabular-nums}
.an-svg .an-cat{fill:var(--mute);font-size:11.5px}
.an-svg .an-leg{fill:var(--mute);font-size:12px}
.an-svg .an-hero{fill:var(--ink);font-family:var(--serif);font-weight:300;font-size:26px}
.an-empty{font-size:13px;color:var(--faint);padding:34px 0;text-align:center;margin:0}
@media (max-width:1060px){.an-cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:860px){.an-grid{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){#view-analytics{animation:none}}

/* ── PAINEL DE EXECUÇÃO AO VIVO (drawer no stage) ──────────────────────── */
#vivo{position:absolute;top:14px;right:16px;z-index:4;max-width:min(400px,46%);
  background:rgba(15,13,16,.9);backdrop-filter:blur(8px);border:1px solid var(--line);
  border-radius:13px;overflow:hidden;transition:border-color .3s var(--ease)}
#vivo.vivo-on{border-color:var(--gold-line)}
#vivo.vivo-fim{border-color:var(--line)}
.vivo-head{display:flex;align-items:center;gap:9px;padding:9px 12px;font-size:12px}
.vivo-head b{font-weight:500;color:var(--mute);letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#vivo.vivo-on .vivo-head b{color:var(--gold)}
.vivo-dot{width:8px;height:8px;border-radius:50%;background:var(--mute);flex:none}
#vivo.vivo-on .vivo-dot{background:var(--gold);animation:pulse 1.4s var(--ease) infinite}
#vivo.vivo-fim .vivo-dot{background:#8FBF8F}
#vivo-custo{margin-left:auto;font-size:11px;color:var(--gold);white-space:nowrap;font-variant-numeric:tabular-nums}
#vivo-x{background:none;border:none;color:var(--faint);font-size:15px;line-height:1;padding:0 2px;cursor:pointer}
#vivo-x:hover{color:var(--ink)}
#vivo-corpo{max-height:min(300px,38vh);overflow-y:auto;padding:4px 12px 10px;border-top:1px solid var(--line)}
.vivo-l{display:flex;gap:8px;font-size:12px;line-height:1.5;color:var(--mute);padding:3px 0;align-items:baseline}
.vivo-ts{font-size:10px;color:var(--faint);font-variant-numeric:tabular-nums;flex:none}
.vivo-l.a span:last-child{color:var(--gold)}
.vivo-l.w span:last-child{color:var(--ink)}
.vivo-l.ok span:last-child{color:#8FBF8F}
.vivo-l.err span:last-child{color:var(--terra)}
.vivo-l.sub{padding-left:44px;font-size:11.5px;color:var(--faint)}
#vivo.vivo-neutro{max-width:min(420px,60%)}
#vivo.vivo-neutro .vivo-head b{font-weight:400;color:var(--faint)}
@media (max-width:760px){#vivo{max-width:calc(100% - 32px)}}
@media (prefers-reduced-motion:reduce){#vivo.vivo-on .vivo-dot{animation:none}}
