:root {
  --cor: #2f6f4f;
  --tinta: #1c2421;
  --fraca: #5d6b64;
  --linha: #e2e7e4;
  --fundo: #f6f8f7;
  --cartao: #fff;
  --aviso: #b25a18;
}
* { box-sizing: border-box; }
/* hidden tem que vencer regras de display de autor (.overlay/.tg-bar usam grid/flex) */
[hidden] { display: none !important; }
body {
  margin: 0;
  font: 15px/1.5 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--tinta);
  background: var(--fundo);
}
h1, h2, h3 { line-height: 1.2; }
button { cursor: pointer; font: inherit; }
.link { background: none; border: none; color: var(--fraca); text-decoration: underline; }

/* Login */
.overlay {
  position: fixed; inset: 0; display: grid; place-items: center;
  background: var(--fundo); z-index: 50;
}
.login-card { width: min(340px, 92vw); display: grid; gap: 12px; }
.login-card h1 { margin: 0; color: var(--cor); }
.login-card .sub { margin: 0 0 8px; color: var(--fraca); font-size: 13px; }
.login-card label { display: grid; gap: 4px; font-size: 13px; color: var(--fraca); }
.login-card input { padding: 9px 10px; border: 1px solid var(--linha); border-radius: 8px; font: inherit; }
.login-card button { padding: 10px; border: none; border-radius: 8px; background: var(--cor); color: #fff; font-weight: 600; }
.erro { color: #b00020; font-size: 13px; margin: 0; }

/* Layout */
header {
  position: sticky; top: 0; z-index: 10;
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
  padding: 12px 20px; background: var(--cartao); border-bottom: 1px solid var(--linha);
}
.brand strong { color: var(--cor); font-size: 16px; }
.header-dir { display: flex; align-items: center; gap: 12px; }
.meta { color: var(--fraca); font-size: 12px; }
#repo-sel { padding: 6px 8px; border: 1px solid var(--linha); border-radius: 8px; }
main { max-width: 1100px; margin: 0 auto; padding: 20px; }
.bloco { margin-bottom: 28px; }
.bloco h2 { color: var(--tinta); border-left: 4px solid var(--cor); padding-left: 10px; }
.ajuda { color: var(--fraca); font-size: 13px; margin: -4px 0 12px; }
.contador { color: var(--fraca); font-weight: 400; font-size: 14px; }

/* Cards */
.cards { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.grid { display: grid; gap: 14px; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.card {
  background: var(--cartao); border: 1px solid var(--linha); border-radius: 12px;
  padding: 14px 16px; box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.card h3 { margin: 0 0 6px; font-size: 15px; }
.card .resumo { color: var(--tinta); font-size: 14px; }
.card .pe { margin: 10px 0 0; padding-left: 18px; color: var(--tinta); font-size: 13px; }
.card .rodape { display: flex; gap: 10px; align-items: center; margin-top: 10px; color: var(--fraca); font-size: 12px; }
.tag { display: inline-block; font-size: 11px; padding: 2px 8px; border-radius: 999px; background: #eef3f0; color: var(--cor); }
.tag.sensivel { background: #fbe9da; color: var(--aviso); }
.pendencia { display: flex; justify-content: space-between; gap: 12px; align-items: start; }
.pendencia .origem { color: var(--fraca); font-size: 12px; }
.btn-tg { white-space: nowrap; border: 1px solid var(--linha); background: #fff; border-radius: 8px; padding: 5px 9px; font-size: 12px; color: var(--cor); }
.btn-tg:hover { background: #eef3f0; }

/* Abas */
.abas { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.abas button { border: 1px solid var(--linha); background: #fff; border-radius: 999px; padding: 6px 14px; color: var(--fraca); }
.abas button.ativa { background: var(--cor); color: #fff; border-color: var(--cor); }

/* Timeline */
.timeline { list-style: none; padding: 0; margin: 0; }
.timeline li { padding: 6px 0 6px 14px; border-left: 2px solid var(--linha); }
.timeline .data { color: var(--cor); font-weight: 600; font-size: 12px; margin-right: 8px; }

/* Barra Telegram */
.tg-bar {
  position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 8px; align-items: center; z-index: 40;
  background: var(--tinta); color: #fff; padding: 8px 10px; border-radius: 12px;
  box-shadow: 0 6px 24px rgba(0,0,0,.25); max-width: 92vw;
}
.tg-bar .tg-ctx { font-size: 12px; max-width: 40vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; opacity: .85; }
.tg-bar button { border: none; border-radius: 8px; padding: 7px 11px; background: var(--cor); color: #fff; font-size: 13px; }
.tg-bar button.ghost { background: transparent; border: 1px solid #5d6b64; }
a.fonte-link { color: var(--cor); }
code { background: #eef3f0; padding: 1px 5px; border-radius: 5px; font-size: 12.5px; }
