:root {
  --azul: #2b5ce6; --azul-escuro: #1e46b8; --azul-claro: #eaf0fe;
  --fundo: #f8f9fb; --card: #ffffff; --borda: #e6e9f0;
  --texto: #1b2230; --texto-suave: #6b7385;
  --verde: #16a34a; --ambar: #d97706; --vermelho: #dc2626; --vermelho-doc: #c00000;
  --sombra: 0 1px 2px rgba(16,24,40,.05), 0 4px 16px rgba(16,24,40,.06);
  --raio: 14px;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--fundo); color: var(--texto);
  font: 400 15px/1.6 'Inter', system-ui, sans-serif; -webkit-font-smoothing: antialiased; }
a { color: var(--azul); text-decoration: none; }
h1, h2, h3 { line-height: 1.25; margin: 0 0 .5em; }

/* Topo */
.topo { background: var(--card); border-bottom: 1px solid var(--borda); position: sticky; top: 0; z-index: 50; }
.topo-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; height: 64px;
  display: flex; align-items: center; gap: 32px; }
.logo { font-weight: 700; font-size: 19px; color: var(--texto); }
.logo span { color: var(--azul); }
.topo-nav { display: flex; gap: 20px; flex: 1; }
.topo-nav a { color: var(--texto-suave); font-weight: 500; padding: 6px 2px; }
.topo-nav a:hover { color: var(--azul); }
.topo-usuario { display: flex; align-items: center; gap: 14px; color: var(--texto-suave); font-size: 14px; }
.topo-usuario .sair { color: var(--vermelho); font-weight: 500; }

/* Layout */
.container { max-width: 1200px; margin: 0 auto; padding: 32px 24px 80px; }
.cabecalho-pagina { display: flex; align-items: center; justify-content: space-between;
  gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.cabecalho-pagina h1 { font-size: 26px; margin: 0; }
.card { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio);
  box-shadow: var(--sombra); padding: 28px; margin-bottom: 24px; }

/* Botões */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 1px solid var(--borda); background: var(--card); color: var(--texto);
  font: 600 14px 'Inter', sans-serif; padding: 11px 20px; border-radius: 10px;
  cursor: pointer; transition: .15s; }
.btn:hover { border-color: var(--azul); color: var(--azul); }
.btn-primario { background: var(--azul); border-color: var(--azul); color: #fff; }
.btn-primario:hover { background: var(--azul-escuro); color: #fff; }
.btn-perigo { color: var(--vermelho); }
.btn-cheio { width: 100%; }
.btn-mini { padding: 6px 12px; font-size: 13px; border-radius: 8px; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* Formulários */
label { display: block; font-weight: 500; font-size: 14px; margin-bottom: 16px; color: var(--texto); }
input[type=text], input[type=email], input[type=password], input[type=url],
input[type=number], select, textarea {
  width: 100%; margin-top: 6px; padding: 11px 14px; font: 400 15px 'Inter', sans-serif;
  border: 1px solid var(--borda); border-radius: 10px; background: #fff; color: var(--texto); }
input:focus, select:focus, textarea:focus { outline: 2px solid var(--azul-claro); border-color: var(--azul); }
textarea { min-height: 110px; resize: vertical; }
.grade-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 24px; }
.grade-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0 24px; }
@media (max-width: 800px) { .grade-2, .grade-3 { grid-template-columns: 1fr; } }
fieldset { border: 1px solid var(--borda); border-radius: var(--raio); padding: 20px 24px; margin: 0 0 24px; }
legend { font-weight: 600; font-size: 15px; color: var(--azul); padding: 0 8px; }

/* Tabela */
table { width: 100%; border-collapse: collapse; font-size: 14px; }
th { text-align: left; color: var(--texto-suave); font-weight: 500; font-size: 13px;
  padding: 10px 14px; border-bottom: 1px solid var(--borda); }
td { padding: 14px; border-bottom: 1px solid var(--borda); }
tr:last-child td { border-bottom: 0; }
tr:hover td { background: var(--fundo); }

/* Badges e alertas */
.badge { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: 12px; font-weight: 600; }
.badge-cinza { background: #eef0f4; color: var(--texto-suave); }
.badge-azul { background: var(--azul-claro); color: var(--azul); }
.badge-verde { background: #e7f6ec; color: var(--verde); }
.badge-ambar { background: #fdf3e3; color: var(--ambar); }
.badge-vermelho { background: #fdeaea; color: var(--vermelho); }
.alerta { padding: 12px 16px; border-radius: 10px; font-size: 14px; margin-bottom: 16px; }
.alerta-erro { background: #fdeaea; color: var(--vermelho); }
.alerta-ok { background: #e7f6ec; color: var(--verde); }

/* Login */
.pagina-login { display: grid; place-items: center; min-height: 100vh; }
.card-login { background: var(--card); border: 1px solid var(--borda); border-radius: 18px;
  box-shadow: var(--sombra); padding: 44px 40px; width: min(400px, 92vw); }
.card-login .logo { font-size: 24px; display: block; text-align: center; }
.login-sub { text-align: center; color: var(--texto-suave); font-size: 14px; margin: 4px 0 24px; }

/* Progresso */
.progresso { height: 10px; background: var(--borda); border-radius: 99px; overflow: hidden; }
.progresso-barra { height: 100%; background: var(--azul); border-radius: 99px;
  transition: width .4s ease; width: 0; }
.progresso-legenda { display: flex; justify-content: space-between; color: var(--texto-suave);
  font-size: 13px; margin-top: 10px; }

/* Estrutura (lista de páginas) */
.lista-paginas { list-style: none; margin: 0; padding: 0; }
.lista-paginas li { display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  border: 1px solid var(--borda); border-radius: 10px; margin-bottom: 8px; background: #fff; }
.lista-paginas li.subpagina { margin-left: 40px; }
.lista-paginas input { margin-top: 0; }
.lista-paginas .acoes { display: flex; gap: 4px; }
.num-pagina { color: var(--texto-suave); font-size: 13px; min-width: 24px; text-align: right; }

/* Editor (formato documento) */
.doc-pagina-titulo { color: var(--vermelho-doc); font-size: 22px; font-weight: 700;
  margin: 40px 0 16px; text-transform: uppercase; }
.doc-secao { border-left: 3px solid var(--borda); padding-left: 18px; margin-bottom: 22px; }
.doc-secao:hover { border-left-color: var(--azul); }
.doc-secao-rotulo { font-size: 12px; font-weight: 600; letter-spacing: .04em;
  text-transform: uppercase; color: var(--texto-suave); margin-bottom: 6px; }
.doc-meta { background: var(--fundo); border: 1px solid var(--borda); border-radius: 10px;
  padding: 16px 18px; margin-bottom: 18px; }
.contador { font-size: 12px; color: var(--texto-suave); }
.contador.estourou { color: var(--vermelho); font-weight: 600; }
.salvando { position: fixed; bottom: 20px; right: 20px; background: var(--texto); color: #fff;
  padding: 8px 16px; border-radius: 8px; font-size: 13px; opacity: 0; transition: .3s; }
.salvando.visivel { opacity: .92; }
