/* Escala Paroquial — estilo */
:root {
  --vinho: #5b1f2b;
  --vinho-escuro: #431620;
  --vinho-claro: #7d3242;
  --papel: #f7f4ee;
  --branco: #ffffff;
  --tinta: #2b2024;
  --cinza: #7a6f72;
  --linha: #e4dcd2;
  --dourado: #a8842f;
  --verde: #2e6b46;
  --verde-fundo: #e7f1ea;
  --vermelho: #9a3030;
  --vermelho-fundo: #f7e7e6;
  --ambar: #8a6116;
  --ambar-fundo: #f6eedb;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  background: var(--papel);
  color: var(--tinta);
  font-size: 15px;
  line-height: 1.5;
}
h1 { font-family: Georgia, "Times New Roman", serif; font-size: 1.5rem; margin: 0 0 .5rem; color: var(--vinho-escuro); font-weight: 600; }
h2.secao { font-family: Georgia, serif; font-size: 1.1rem; margin: 2rem 0 .4rem; color: var(--vinho-escuro);
  border-bottom: 2px solid var(--dourado); display: inline-block; padding-bottom: 2px; }
.sub { color: var(--cinza); margin: 0 0 1rem; }
a { color: var(--vinho); }

/* ---------- Topo ---------- */
.topo { background: var(--vinho); color: #f3e9e0; }
.topo-inner {
  max-width: 1100px; margin: 0 auto; padding: .6rem 1rem;
  display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap;
}
.marca { color: #fff; text-decoration: none; font-family: Georgia, serif; font-size: 1.1rem; white-space: nowrap; }
.marca span { letter-spacing: .02em; }
.menu { display: flex; gap: .2rem; flex-wrap: wrap; flex: 1; }
.menu a {
  color: #ecd9cf; text-decoration: none; padding: .35rem .6rem; border-radius: 6px; font-size: .92rem;
}
.menu a:hover { background: var(--vinho-claro); color: #fff; }
.sessao { display: flex; gap: .8rem; align-items: center; font-size: .88rem; }
.sessao a { color: #ecd9cf; }
.quem { color: #fff; font-weight: 600; }

/* ---------- Conteúdo ---------- */
.conteudo { max-width: 1100px; margin: 1.5rem auto 3rem; padding: 0 1rem; }
.cabecalho-pagina { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; }

.aviso { padding: .6rem .9rem; border-radius: 8px; margin-bottom: 1rem; border: 1px solid; }
.aviso-ok { background: var(--verde-fundo); color: var(--verde); border-color: #c4dccd; }
.aviso-erro { background: var(--vermelho-fundo); color: var(--vermelho); border-color: #e6c5c3; }

/* ---------- Botões ---------- */
.btn {
  display: inline-block; padding: .45rem .9rem; border-radius: 8px; border: 1px solid var(--linha);
  background: var(--branco); color: var(--tinta); text-decoration: none; font-size: .92rem; cursor: pointer;
}
.btn:hover { border-color: var(--vinho); }
.btn-primario { background: var(--vinho); border-color: var(--vinho); color: #fff; }
.btn-primario:hover { background: var(--vinho-claro); }
.btn-perigo { background: var(--branco); color: var(--vermelho); border-color: #dcb6b4; }
.btn-perigo:hover { background: var(--vermelho-fundo); }
.btn-largo { width: 100%; }
.btn-mini { padding: .2rem .55rem; font-size: .82rem; }
.btn-ok { background: var(--verde); border-color: var(--verde); color: #fff; }
.btn-falta { background: var(--vermelho); border-color: var(--vermelho); color: #fff; }
.btn-neutro { background: var(--cinza); border-color: var(--cinza); color: #fff; }

/* ---------- Formulários ---------- */
.form { max-width: 460px; background: var(--branco); border: 1px solid var(--linha); border-radius: 10px; padding: 1.2rem; }
.form label, .filtros label { display: block; margin-bottom: .8rem; font-weight: 600; font-size: .9rem; color: var(--vinho-escuro); }
input[type=text], input[type=password], input[type=date], input[type=time], input[type=number], select, textarea {
  display: block; width: 100%; margin-top: .25rem; padding: .45rem .6rem;
  border: 1px solid var(--linha); border-radius: 8px; font: inherit; background: #fff;
}
input:focus, select:focus, textarea:focus, .btn:focus { outline: 2px solid var(--dourado); outline-offset: 1px; }
.form .check { display: flex; align-items: center; gap: .5rem; font-weight: 400; }
.form .check input { width: auto; margin: 0; }
.acoes { display: flex; gap: .6rem; margin-top: 1rem; }
.grupo { border: 1px solid var(--linha); border-radius: 8px; padding: .8rem 1rem; margin: 0 0 .8rem; }
.grupo legend { font-weight: 600; font-size: .88rem; color: var(--vinho-escuro); padding: 0 .3rem; }
.grupo .inline { display: flex; align-items: center; justify-content: space-between; gap: .8rem; font-weight: 400; }
.grupo .inline input { width: 90px; margin: 0; }
.dica { color: var(--cinza); font-size: .82rem; margin: .4rem 0 0; }

.filtros { display: flex; gap: .8rem; align-items: flex-end; flex-wrap: wrap;
  background: var(--branco); border: 1px solid var(--linha); border-radius: 10px; padding: .8rem 1rem; margin-bottom: 1.2rem; }
.filtros label { margin: 0; }
.filtros input, .filtros select { width: auto; min-width: 140px; }

/* ---------- Tabelas ---------- */
.tabela { width: 100%; border-collapse: collapse; background: var(--branco); border: 1px solid var(--linha); border-radius: 10px; overflow: hidden; }
.tabela th { text-align: left; font-size: .8rem; text-transform: uppercase; letter-spacing: .04em;
  color: var(--cinza); padding: .55rem .8rem; border-bottom: 2px solid var(--linha); background: #fbf9f5; }
.tabela td { padding: .55rem .8rem; border-bottom: 1px solid var(--linha); vertical-align: middle; }
.tabela tr:last-child td { border-bottom: 0; }
.acoes-td { text-align: right; white-space: nowrap; }
.presenca-form { display: flex; gap: .3rem; }

/* ---------- Cartões de escala ---------- */
.lista-escalas { display: flex; flex-direction: column; gap: .6rem; }
.cartao-escala {
  display: flex; align-items: center; gap: 1rem; text-decoration: none; color: var(--tinta);
  background: var(--branco); border: 1px solid var(--linha); border-left: 4px solid var(--vinho);
  border-radius: 10px; padding: .7rem .9rem;
}
.cartao-escala:hover { border-color: var(--vinho); }
.data-bloco { text-align: center; min-width: 56px; color: var(--vinho); }
.data-bloco.apagado { color: var(--cinza); }
.data-bloco .dia { display: block; font-family: Georgia, serif; font-size: 1.5rem; line-height: 1; font-weight: 700; }
.data-bloco .mes { font-size: .75rem; }
.cartao-escala .info { flex: 1; display: flex; flex-direction: column; }
.cartao-escala .info span { color: var(--cinza); font-size: .88rem; }
.mini { font-size: .8rem; }

.selo { font-size: .74rem; padding: .15rem .55rem; border-radius: 99px; background: #eee4d8; color: var(--cinza); white-space: nowrap; }
.selo-ok { background: var(--verde-fundo); color: var(--verde); }
.selo-atencao { background: var(--ambar-fundo); color: var(--ambar); }

.vazio { background: var(--branco); border: 1px dashed var(--linha); border-radius: 10px; padding: 2rem; text-align: center; color: var(--cinza); }
.vazio .btn { margin-top: .8rem; }

/* ---------- Login ---------- */
.cartao-login { max-width: 360px; margin: 8vh auto 0; background: var(--branco); border: 1px solid var(--linha);
  border-top: 5px solid var(--vinho); border-radius: 12px; padding: 2rem; text-align: center; }
.cartao-login h1 { margin-bottom: .2rem; }
.cartao-login form { text-align: left; margin-top: 1.2rem; }
.cartao-login label { display: block; margin-bottom: .8rem; font-weight: 600; font-size: .9rem; color: var(--vinho-escuro); }
.login-marca { font-size: 2rem; color: var(--dourado); }

/* ---------- Folha de relatório ---------- */
.folha { background: var(--branco); border: 1px solid var(--linha); border-radius: 10px; padding: 1.5rem; }
.folha-cabecalho { display: flex; gap: .9rem; align-items: center; border-bottom: 2px solid var(--vinho); padding-bottom: .8rem; margin-bottom: 1rem; }
.folha-cabecalho .cruz { font-size: 1.8rem; color: var(--dourado); }
.folha-cabecalho h2 { margin: 0; font-family: Georgia, serif; color: var(--vinho-escuro); }
.folha-cabecalho p { margin: 0; color: var(--cinza); font-size: .9rem; }
.folha-unidade { font-family: Georgia, serif; color: var(--vinho); margin: 1.2rem 0 .4rem; }
.caixa-texto { font-family: ui-monospace, Consolas, monospace; font-size: .85rem; margin-bottom: .6rem; }

/* ---------- Responsivo ---------- */
@media (max-width: 720px) {
  .tabela { display: block; overflow-x: auto; }
  .topo-inner { gap: .5rem; }
  .cabecalho-pagina { flex-direction: column; }
}

/* ---------- Impressão ---------- */
@media print {
  .no-print { display: none !important; }
  body { background: #fff; font-size: 12px; }
  .conteudo { margin: 0; max-width: none; }
  .folha { border: 0; padding: 0; }
  .tabela, .tabela th, .tabela td { border-color: #bbb; }
}

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
}
