:root{
  --teal:#2E6E78; --navy:#00223E; --azul:#1B8FD4; --verde:#006F3A;
  --verm:#FA121F; --fundo:#F2F1EC; --texto:#2A2E33; --cinza:#8a8f96;
  --card:#ffffff; --linha:#e7e4dc; --sombra:0 2px 10px rgba(0,34,62,.07);
  --grad:linear-gradient(120deg,#2E6E78,#1B8FD4);
  --h-top:calc(52px + env(safe-area-inset-top));    /* altura aprox. da topbar */
  --h-bot:calc(53px + env(safe-area-inset-bottom)); /* altura aprox. da tabbar */
  --vvh:100dvh;  /* altura realmente visível; o JS atualiza com o teclado aberto */
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--fundo);color:var(--texto);
  font-family:'Poppins','Segoe UI',system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;overscroll-behavior-y:contain;
}
.hidden{display:none !important}
.nome{font-weight:300;letter-spacing:1px}
.nome b{color:var(--navy);font-weight:600}
.nome i{color:var(--teal);font-style:normal;font-weight:600}

/* ---------- LOGIN ---------- */
.login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 80% at 50% 0%,#fff 0%,var(--fundo) 70%);padding:24px}
.login-card{width:100%;max-width:340px;text-align:center}
.logo-big{width:84px;height:76px;margin-bottom:6px}
.login-card .nome{font-size:30px}
.login-sub{color:var(--cinza);margin:6px 0 26px;font-size:14px}
#usuario,#senha,.campo{width:100%;padding:15px 16px;border:1.5px solid var(--linha);border-radius:14px;
  font-size:16px;font-family:inherit;background:#fff;outline:none;transition:border-color .15s}
#usuario:focus,#senha:focus,.campo:focus{border-color:var(--azul)}
#usuario{margin-bottom:10px}
.btn-primary{width:100%;margin-top:12px;padding:15px;border:0;border-radius:14px;
  background:var(--grad);color:#fff;font-size:16px;font-weight:600;font-family:inherit;
  cursor:pointer;box-shadow:0 4px 14px rgba(27,143,212,.32);transition:transform .08s,opacity .15s}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{opacity:.6}
.login-erro{color:var(--verm);font-size:14px;margin-top:14px;min-height:18px}

/* ---------- USUÁRIOS (master) ---------- */
.ulist{display:flex;flex-direction:column;gap:8px}
.urow{background:#fff;border:1px solid var(--linha);border-radius:14px;padding:12px 14px}
.uinfo b{color:var(--navy)}
.ulogin{color:var(--cinza);font-size:13px}
.utags{margin-top:7px;display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:12px;padding:3px 9px;border-radius:999px;background:var(--fundo);color:var(--navy)}
.tag.master{background:rgba(27,143,212,.14);color:var(--azul);font-weight:600}
.tag.vazia{background:#fbeaea;color:var(--verm)}
.uhead{display:flex;align-items:center;justify-content:space-between;gap:10px}
.gcarta{margin-top:8px;font-size:13px;color:var(--cinza);line-height:1.4}
.mini{flex:none;border:1px solid var(--linha);background:#fff;color:var(--azul);font-family:inherit;
  font-size:13px;font-weight:600;padding:5px 12px;border-radius:9px;cursor:pointer}
.ucard{background:#fff;border:1px solid var(--linha);border-radius:16px;padding:16px}
.ucard-tit{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:12px}
.ucard .campo{margin-bottom:10px}
textarea.campo.area{resize:vertical;line-height:1.45;min-height:90px}
select.campo{appearance:none;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%237b8a99' stroke-width='2' fill='none' stroke-linecap='round'/></svg>") no-repeat right 16px center}
.chk-tit{font-size:13px;color:var(--cinza);margin:6px 0 8px}
.chks{display:flex;flex-wrap:wrap;gap:10px 16px;margin-bottom:6px}
.chk{display:flex;align-items:center;gap:7px;font-size:15px;color:var(--navy);cursor:pointer}
.chk input{width:18px;height:18px;accent-color:var(--azul)}

/* ---------- MODAL (trocar senha) ---------- */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;
  background:rgba(0,34,62,.34);backdrop-filter:blur(3px);padding:24px}
.modal-card{width:100%;max-width:340px;background:#fff;border-radius:18px;padding:22px;
  box-shadow:0 18px 50px rgba(0,34,62,.3)}
.modal-card h3{margin:2px 0 16px;font-size:18px;color:var(--navy);font-weight:600}
.modal-card .campo{margin-bottom:10px}
.modal-acoes{display:flex;gap:10px;margin-top:6px}
.modal-acoes .btn-primary,.modal-acoes .btn-sec{margin-top:8px}
.btn-sec{flex:1;padding:15px;border:1.5px solid var(--linha);border-radius:14px;background:#fff;
  color:var(--cinza);font-size:16px;font-weight:600;font-family:inherit;cursor:pointer}
.modal-acoes .btn-primary{flex:1}

/* ---------- APP shell ---------- */
.app{display:flex;flex-direction:column;min-height:100%;padding-bottom:calc(74px + env(safe-area-inset-bottom))}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:9px;
  padding:calc(12px + env(safe-area-inset-top)) 16px 12px;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--linha)}
.logo-sm{width:30px;height:27px;flex:none}
.nome.sm{font-size:18px}
.titulo-aba{margin-left:auto;font-size:13px;color:var(--cinza);font-weight:500}
.icon-btn{margin-left:10px;width:36px;height:36px;border:0;border-radius:10px;background:var(--fundo);
  color:var(--navy);font-size:18px;cursor:pointer}
.view{flex:1;padding:16px;max-width:620px;width:100%;margin:0 auto}
.carregando{color:var(--cinza);text-align:center;padding:40px 0;font-size:14px}
/* aba Chat ocupa a tela toda (duas colunas no PC), sem o limite de 620px nem rolagem da página */
.view.chat-mode{max-width:none;width:100%;padding:0;margin:0;min-height:0;overflow:hidden;
  height:calc(100vh - var(--h-top) - var(--h-bot));height:calc(var(--vvh) - var(--h-top) - var(--h-bot))}
.app:has(.chat-mode){padding-bottom:0 !important}
/* teclado aberto (iPhone): a barra de baixo some e o chat ocupa toda a área visível acima do teclado */
body.kb-open .tabbar{display:none}
body.kb-open .view.chat-mode{height:calc(var(--vvh) - var(--h-top))}

/* ---------- TABBAR ---------- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;
  background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-top:1px solid var(--linha);
  padding-bottom:env(safe-area-inset-bottom)}
.tab{flex:1;border:0;background:none;padding:9px 0 8px;cursor:pointer;position:relative;
  display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--cinza);font-family:inherit}
.tab .ico{font-size:21px;filter:grayscale(.4);opacity:.7;transition:.15s}
.tab .lbl{font-size:11px;font-weight:500}
.tab.ativa{color:var(--navy)}
.tab.ativa .ico{filter:none;opacity:1;transform:translateY(-1px)}
.tab.ativa::before{content:"";position:absolute;top:0;width:30px;height:3px;border-radius:3px;background:var(--grad)}
.badge-num{position:absolute;top:5px;right:calc(50% - 26px);background:var(--verm);color:#fff;
  font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;padding:0 4px}

/* ---------- seções/cartões ---------- */
.sec-tit{font-size:13px;font-weight:600;color:var(--navy);text-transform:uppercase;
  letter-spacing:.5px;margin:6px 2px 12px;display:flex;align-items:center;gap:8px}
.sec-tit .n{background:var(--navy);color:#fff;border-radius:20px;font-size:11px;padding:1px 8px}
.vazio{color:var(--cinza);font-size:14px;text-align:center;background:var(--card);
  border:1px dashed var(--linha);border-radius:16px;padding:26px 16px}
.vazio .em{font-size:30px;display:block;margin-bottom:8px}

.pedido{background:var(--card);border:1px solid var(--linha);border-radius:16px;
  padding:15px;margin-bottom:12px;box-shadow:var(--sombra);border-left:4px solid var(--azul)}
.pedido.ok{border-left-color:var(--verde)} .pedido.no{border-left-color:var(--verm)}
.pedido .cab{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.pedido .grp{font-weight:600;color:var(--navy);font-size:14px}
.pedido .badge{margin-left:auto;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;
  text-transform:uppercase;letter-spacing:.4px}
.badge.p{background:#e3f1fb;color:#0f6cb0}
.badge.ok{background:#e2f3ea;color:var(--verde)}
.badge.no{background:#fde3e4;color:var(--verm)}
.pedido .txt{font-size:16px;font-weight:500;margin:3px 0 6px;line-height:1.35}
.pedido .meta{font-size:12px;color:var(--cinza)}
.pedido .lib{font-size:13px;color:#4a4f55;background:var(--fundo);border-radius:10px;
  padding:9px 11px;margin:9px 0 0;line-height:1.45}
.acoes{display:flex;gap:10px;margin-top:13px}
.acoes button{flex:1;padding:13px;border:0;border-radius:12px;font-size:15px;font-weight:600;
  font-family:inherit;cursor:pointer;transition:transform .08s,opacity .15s}
.acoes button:active{transform:scale(.97)}
.acoes button:disabled{opacity:.5}
.bt-ok{background:var(--verde);color:#fff}
.bt-no{background:#fff;color:var(--verm);border:1.5px solid var(--verm) !important}

/* ---------- KPIs / gastos ---------- */
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}
.kpi{background:var(--card);border:1px solid var(--linha);border-radius:16px;padding:15px;box-shadow:var(--sombra)}
.kpi .v{font-size:26px;font-weight:700;color:var(--navy);line-height:1.1}
.kpi .v small{font-size:14px;font-weight:600;color:var(--cinza)}
.kpi .k{font-size:12px;color:var(--cinza);margin-top:4px}
.kpi.full{grid-column:1/3}
.barras{display:flex;align-items:flex-end;gap:7px;height:90px;margin:14px 4px 4px}
.barra{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%;justify-content:flex-end}
.barra .b{width:100%;max-width:26px;border-radius:6px 6px 0 0;background:var(--grad);min-height:3px;transition:height .3s}
.barra .d{font-size:10px;color:var(--cinza)}
.nota{font-size:12px;color:var(--cinza);margin-top:14px;line-height:1.5}

/* ---------- VPS ---------- */
.gauge{background:var(--card);border:1px solid var(--linha);border-radius:16px;padding:15px;
  margin-bottom:12px;box-shadow:var(--sombra)}
.gauge .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.gauge .lab{font-size:14px;font-weight:500;color:var(--navy)}
.gauge .val{font-size:13px;color:var(--cinza)}
.bar{height:9px;border-radius:6px;background:var(--fundo);overflow:hidden}
.bar > i{display:block;height:100%;border-radius:6px;background:var(--grad)}
.bar > i.alto{background:linear-gradient(120deg,#e8a317,#FA121F)}
.linha-info{display:flex;justify-content:space-between;padding:13px 15px;background:var(--card);
  border:1px solid var(--linha);border-radius:14px;margin-bottom:10px;font-size:14px;box-shadow:var(--sombra)}
.linha-info b{color:var(--navy)}
.online{color:var(--verde);font-weight:600}
.online::before{content:"●";margin-right:5px}

/* ========== CHAT — layout messenger moderno (duas colunas) ========== */
.chat-wrap{display:flex;height:100%;min-height:0;background:var(--fundo)}

/* ----- coluna da lista de conversas ----- */
.chat-lista{display:flex;flex-direction:column;width:100%;min-height:0;
  padding:14px 12px 12px;gap:12px;background:#fff}
.novo-chat{flex:none;display:flex;align-items:center;justify-content:center;gap:7px;
  background:var(--grad);color:#fff;border:0;border-radius:14px;padding:13px;
  font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;letter-spacing:.2px;
  box-shadow:0 6px 18px rgba(27,143,212,.30);transition:transform .08s,box-shadow .15s}
.novo-chat:hover{box-shadow:0 8px 22px rgba(27,143,212,.40)}
.novo-chat:active{transform:scale(.98)}
.lista-conversas{display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0;
  padding-bottom:4px;margin:0 -6px}
.conversa{position:relative;display:flex;flex-direction:column;gap:3px;background:transparent;
  border:0;border-radius:14px;padding:11px 12px 11px 56px;cursor:pointer;font-family:inherit;
  text-align:left;transition:background .14s}
.conversa::before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:34px;height:34px;border-radius:50%;background:var(--grad);opacity:.92;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.35)}
.conversa::after{content:"💬";position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:34px;height:34px;display:grid;place-items:center;font-size:15px}
.conversa:hover{background:var(--fundo)}
.conversa.ativa{background:rgba(27,143,212,.10)}
.conversa.ativa::before{box-shadow:inset 0 0 0 2px rgba(255,255,255,.5),0 0 0 2px rgba(27,143,212,.35)}
.conversa .c-top{display:flex;align-items:center;gap:10px}
.conversa .ct{font-size:15px;font-weight:600;color:var(--navy);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.conversa .cq{font-size:11px;color:var(--cinza);flex:none;font-weight:500}
.conversa .cprev{font-size:13px;color:var(--cinza);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}

/* ----- coluna da conversa aberta ----- */
.chat-conv{display:flex;flex-direction:column;width:100%;min-height:0;flex:1;background:var(--fundo)}
.conv-topo{flex:1;min-height:0;display:flex;flex-direction:column}
.conv-vazia{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  color:var(--cinza);text-align:center;font-size:14px;padding:24px}
.conv-vazia .cv-em{font-size:30px;width:84px;height:84px;display:grid;place-items:center;border-radius:50%;
  background:var(--grad);box-shadow:0 10px 30px rgba(27,143,212,.30)}
.cv-head{display:flex;align-items:center;gap:8px;flex:none;padding:11px 14px;
  background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--linha);
  box-shadow:0 1px 6px rgba(0,34,62,.04)}
.cv-head .voltar{border:0;background:none;cursor:pointer;padding:0 6px 0 0;font-size:26px;line-height:1;color:var(--azul)}
.cv-head .voltar:active{transform:scale(.9)}
.cv-tit{flex:1;font-size:16px;font-weight:600;color:var(--navy);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cv-acao{flex:none;border:0;background:none;font-size:16px;cursor:pointer;padding:6px;line-height:1;opacity:.7;border-radius:9px;transition:background .12s,opacity .12s}
.cv-acao:hover{opacity:1;background:var(--fundo)}
.cv-acao:active{transform:scale(.9)}

/* fundo do chat: claro com um padrão sutil de pontos (estilo messenger, tema CLARO) */
.msgs{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:7px;padding:18px 14px;
  background-color:var(--fundo);
  background-image:radial-gradient(rgba(0,34,62,.045) 1px,transparent 1px);
  background-size:22px 22px}
.bolha{position:relative;max-width:76%;padding:10px 14px;border-radius:18px;font-size:15px;line-height:1.45;
  white-space:normal;word-wrap:break-word;overflow-wrap:anywhere;animation:bolha-in .2s ease-out}
@keyframes bolha-in{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}
/* bolhas coladas do mesmo lado: menos respiro */
.bolha.eu + .bolha.eu,.bolha.ia + .bolha.ia{margin-top:-3px}

/* celular: uma coluna de cada vez (lista OU conversa) */
.chat-wrap:not(.ver-conv) .chat-conv{display:none}
.chat-wrap.ver-conv .chat-lista{display:none}
/* PC: as duas lado a lado */
@media(min-width:900px){
  .chat-lista{width:320px;flex:none;border-right:1px solid var(--linha)}
  .chat-conv{flex:1}
  .chat-wrap:not(.ver-conv) .chat-conv{display:flex}
  .chat-wrap.ver-conv .chat-lista{display:flex}
  .cv-head .voltar{display:none}
  .bolha{max-width:66%}
}
.bolha code{background:rgba(0,34,62,.06);padding:1px 5px;border-radius:5px;font-size:13px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
/* minha bolha — gradiente, "rabinho" no canto inferior direito */
.bolha.eu{align-self:flex-end;background:var(--grad);color:#fff;border-bottom-right-radius:6px;
  box-shadow:0 2px 8px rgba(27,143,212,.28)}
.bolha.eu code{background:rgba(255,255,255,.2)}
.bolha.eu::after{content:"";position:absolute;right:-5px;bottom:0;width:14px;height:16px;
  background:var(--azul);border-bottom-left-radius:16px;z-index:-1}
/* bolha do TOPNEX — branca, "rabinho" no canto inferior esquerdo */
.bolha.ia{align-self:flex-start;background:#fff;border:1px solid var(--linha);
  color:var(--texto);border-bottom-left-radius:6px;box-shadow:0 1px 4px rgba(0,34,62,.06)}
.bolha.ia::after{content:"";position:absolute;left:-5px;bottom:-1px;width:14px;height:16px;
  background:#fff;border:1px solid var(--linha);border-top:0;border-right:0;border-bottom-right-radius:16px;z-index:-1}
.bolha.sis{align-self:center;background:rgba(0,34,62,.05);color:var(--cinza);font-size:12.5px;
  padding:5px 12px;border-radius:12px;box-shadow:none;max-width:90%;text-align:center}

.statusbar{flex:none;display:flex;align-items:center;gap:7px;padding:6px 14px;
  color:var(--cinza);font-size:13px;border-top:1px solid var(--linha);background:#fff}
.statusbar .dot{width:8px;height:8px;border-radius:50%;background:var(--azul);animation:pulso 1s infinite;flex:none}
.statusbar .st-txt{flex:none}
.statusbar .ha{color:var(--cinza);opacity:.75}
@keyframes pulso{0%,100%{opacity:.3}50%{opacity:1}}
/* barra de progresso indeterminada (faixa que desliza) */
.cv-prog{position:relative;flex:1;height:3px;border-radius:3px;background:var(--linha);overflow:hidden;min-width:40px}
.cv-prog i{position:absolute;top:0;height:100%;border-radius:3px;background:var(--azul);animation:progdesliza 1.25s ease-in-out infinite}
@keyframes progdesliza{0%{left:-38%;width:38%}50%{width:54%}100%{left:100%;width:38%}}
/* três pontinhos "digitando" dentro da bolha */
.digit-dots{display:inline-flex;gap:5px;padding:2px 0}
.digit-dots i{width:7px;height:7px;border-radius:50%;background:var(--azul);opacity:.4;animation:digbounce 1.25s infinite}
.digit-dots i:nth-child(2){animation-delay:.18s}
.digit-dots i:nth-child(3){animation-delay:.36s}
@keyframes digbounce{0%,60%,100%{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
/* cursor piscando no fim do texto que está sendo escrito ao vivo */
.digit-caret{display:inline-block;width:7px;height:14px;margin-left:2px;vertical-align:-2px;background:var(--azul);
  border-radius:2px;animation:pisca 1s steps(2) infinite}
@keyframes pisca{50%{opacity:0}}

/* composer: barra flutuante em "pill" único que abraça os botões */
.composer{flex:none;display:flex;align-items:flex-end;gap:6px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.98);border-top:1px solid var(--linha);box-shadow:0 -2px 10px rgba(0,34,62,.04)}
.composer textarea{flex:1;resize:none;border:1.5px solid var(--linha);border-radius:22px;
  padding:11px 16px;font-size:16px;font-family:inherit;background:var(--fundo);outline:none;
  max-height:140px;line-height:1.4;transition:border-color .15s,background .15s}
.composer textarea:focus{border-color:var(--azul);background:#fff}
.bt-enviar{flex:none;width:46px;height:46px;border:0;border-radius:50%;background:var(--grad);
  color:#fff;font-size:19px;cursor:pointer;box-shadow:0 4px 14px rgba(27,143,212,.34);
  display:grid;place-items:center;transition:transform .08s,box-shadow .15s}
.bt-enviar:hover{box-shadow:0 6px 18px rgba(27,143,212,.45)}
.bt-enviar:active{transform:scale(.92)}
.bt-enviar:disabled{opacity:.5}
.bt-icone{flex:none;width:42px;height:42px;border:0;border-radius:50%;background:transparent;
  color:var(--teal);font-size:20px;cursor:pointer;display:grid;place-items:center;line-height:1;transition:background .12s,transform .08s}
.bt-icone:hover{background:var(--fundo)}
.bt-icone:active{transform:scale(.9)}
.bt-icone.gravando{background:rgba(250,18,31,.12);color:var(--verm);animation:pulso 1s infinite}

/* ---------- anexos no chat ---------- */
.anexos-fila{flex:none;display:flex;gap:8px;overflow-x:auto;padding:8px 12px;
  background:rgba(255,255,255,.97);border-top:1px solid var(--linha)}
.anx-chip{flex:none;display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--linha);
  border-radius:12px;padding:5px 8px;max-width:200px;box-shadow:var(--sombra)}
.anx-chip img{width:34px;height:34px;border-radius:8px;object-fit:cover;flex:none}
.anx-ico{font-size:20px;line-height:1}
.anx-nome{font-size:12px;color:var(--texto);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.anx-x{flex:none;border:0;background:none;color:var(--cinza);font-size:14px;cursor:pointer;padding:0 2px}
.bolha-img{max-width:230px;max-height:300px;border-radius:11px;display:block;cursor:pointer}
.bolha-aud{max-width:240px;height:38px;display:block}
.bolha-cap{margin-top:6px;font-size:14px}
.bolha-arq{color:inherit;text-decoration:underline;font-weight:500}
.bolha.eu .bolha-arq{color:#fff}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:calc(90px + env(safe-area-inset-bottom));transform:translateX(-50%);
  background:var(--navy);color:#fff;padding:11px 18px;border-radius:24px;font-size:14px;z-index:50;
  box-shadow:0 6px 20px rgba(0,0,0,.25);max-width:90%;text-align:center}
@keyframes fadein{from{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%,0)}}
.toast:not(.hidden){animation:fadein .2s}

/* ---------- ditar carta por voz ---------- */
.chk-tit-carta{display:flex;align-items:center;gap:10px;justify-content:space-between}
.mic-btn{flex:none;border:1.5px solid var(--azul);background:#fff;color:var(--azul);
  font-family:inherit;font-size:13px;font-weight:600;padding:6px 12px;border-radius:999px;cursor:pointer}
.mic-btn:active{transform:scale(.97)}
.mic-btn:disabled{opacity:.55}
.mic-btn.rec{border-color:var(--verm);color:#fff;background:var(--verm);animation:micpulse 1.1s infinite}
@keyframes micpulse{0%,100%{box-shadow:0 0 0 0 rgba(250,18,31,.35)}50%{box-shadow:0 0 0 7px rgba(250,18,31,0)}}
.mic-status{font-size:13px;color:var(--cinza);line-height:1.4;margin:2px 0 8px;min-height:16px}
.mic-status .mic-ok{color:var(--verde);font-weight:600}
