:root{
  --azul:#4a6cf7;
  --azul-escuro:#3451c6;
  --verde:#2bb673;
  --verde-claro:#e6f7ef;
  --vermelho:#e5484d;
  --vermelho-claro:#fdecec;
  --amarelo:#f5a623;
  --amarelo-claro:#fef5e7;
  --texto:#1c2333;
  --texto-suave:#6b7280;
  --borda:#e6e8ee;
  --fundo:#f5f6fa;
  --branco:#ffffff;
  --sombra:0 1px 3px rgba(16,24,40,.06),0 1px 2px rgba(16,24,40,.04);
  --sombra-md:0 4px 16px rgba(16,24,40,.08);
  --raio:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Nunito',system-ui,sans-serif;
  background:var(--fundo);
  color:var(--texto);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--azul);text-decoration:none}

/* ---------- TOPO ---------- */
.topo{background:var(--branco);border-bottom:1px solid var(--borda);position:sticky;top:0;z-index:50}
.topo-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;gap:18px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.18rem;color:var(--texto)}
.logo-icone{color:var(--amarelo);font-size:1.4rem}
.nav{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.nav a{padding:8px 14px;border-radius:9px;color:var(--texto-suave);font-weight:600;font-size:.94rem;transition:.15s}
.nav a:hover{background:var(--fundo);color:var(--texto)}
.nav a.ativo{background:var(--azul);color:#fff}
.nav a.sair{color:var(--vermelho)}
.nav a.sair:hover{background:var(--vermelho-claro)}
.menu-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--texto)}

/* ---------- CONTEUDO ---------- */
.conteudo{max-width:1180px;margin:0 auto;padding:28px 22px 60px}
.pagina-titulo{font-size:1.7rem;font-weight:800;margin-bottom:4px}
.pagina-sub{color:var(--texto-suave);margin-bottom:26px}
.linha-titulo{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:26px}
.linha-titulo .pagina-sub{margin-bottom:0}

/* ---------- CARDS ---------- */
.card{background:var(--branco);border:1px solid var(--borda);border-radius:var(--raio);box-shadow:var(--sombra);padding:22px}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:28px}
.stat{background:var(--branco);border:1px solid var(--borda);border-radius:var(--raio);padding:20px;box-shadow:var(--sombra)}
.stat .rotulo{color:var(--texto-suave);font-size:.86rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat .numero{font-size:1.9rem;font-weight:800;margin-top:6px}
.stat .extra{font-size:.85rem;color:var(--texto-suave);margin-top:2px}
.stat.azul{border-left:4px solid var(--azul)}
.stat.verde{border-left:4px solid var(--verde)}
.stat.amarelo{border-left:4px solid var(--amarelo)}
.stat.vermelho{border-left:4px solid var(--vermelho)}

/* ---------- TABELAS ---------- */
.tabela-wrap{overflow-x:auto;background:var(--branco);border:1px solid var(--borda);border-radius:var(--raio);box-shadow:var(--sombra)}
table{width:100%;border-collapse:collapse;font-size:.94rem}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--borda)}
th{background:#fafbfc;font-weight:700;color:var(--texto-suave);font-size:.82rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbff}
.td-acoes{display:flex;gap:8px;white-space:nowrap}

/* ---------- BADGES ---------- */
.badge{display:inline-block;padding:3px 11px;border-radius:20px;font-size:.78rem;font-weight:700}
.badge.verde{background:var(--verde-claro);color:#15784e}
.badge.vermelho{background:var(--vermelho-claro);color:#c0383c}
.badge.amarelo{background:var(--amarelo-claro);color:#b9770f}
.badge.azul{background:#eaeefe;color:var(--azul-escuro)}
.badge.cinza{background:#eef0f4;color:var(--texto-suave)}

/* ---------- BOTOES ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:10px;font-weight:700;font-size:.92rem;border:none;cursor:pointer;transition:.15s;font-family:inherit}
.btn-primario{background:var(--azul);color:#fff}
.btn-primario:hover{background:var(--azul-escuro)}
.btn-verde{background:var(--verde);color:#fff}
.btn-verde:hover{filter:brightness(.94)}
.btn-claro{background:var(--fundo);color:var(--texto);border:1px solid var(--borda)}
.btn-claro:hover{background:#ececf2}
.btn-perigo{background:var(--vermelho);color:#fff}
.btn-perigo:hover{filter:brightness(.94)}
.btn-sm{padding:6px 12px;font-size:.84rem;border-radius:8px}
.btn-wpp{background:#25d366;color:#fff}
.btn-wpp:hover{filter:brightness(.93)}

/* ---------- FORMS ---------- */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.campo{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.campo label{font-weight:700;font-size:.9rem}
.campo input,.campo select,.campo textarea{
  padding:11px 13px;border:1px solid var(--borda);border-radius:10px;font-size:.96rem;font-family:inherit;background:var(--branco);color:var(--texto);transition:.15s
}
.campo input:focus,.campo select:focus,.campo textarea:focus{outline:none;border-color:var(--azul);box-shadow:0 0 0 3px rgba(74,108,247,.12)}
.campo textarea{resize:vertical;min-height:80px}
.campo .ajuda{font-size:.8rem;color:var(--texto-suave)}
.form-acoes{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}

/* ---------- ALERTAS ---------- */
.alerta{padding:13px 16px;border-radius:10px;margin-bottom:20px;font-weight:600;font-size:.93rem}
.alerta.sucesso{background:var(--verde-claro);color:#15784e}
.alerta.erro{background:var(--vermelho-claro);color:#c0383c}
.alerta.aviso{background:var(--amarelo-claro);color:#b9770f}

/* ---------- LOGIN ---------- */
.login-tela{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#4a6cf7 0%,#6a4cf7 100%)}
.login-card{background:#fff;border-radius:20px;padding:40px 34px;width:100%;max-width:400px;box-shadow:0 20px 50px rgba(0,0,0,.2)}
.login-card h1{font-size:1.5rem;text-align:center;margin-bottom:6px}
.login-card .sub{text-align:center;color:var(--texto-suave);margin-bottom:26px}
.login-card .btn{width:100%;justify-content:center;margin-top:6px}

/* ---------- DIVERSOS ---------- */
.vazio{text-align:center;padding:50px 20px;color:var(--texto-suave)}
.secao-titulo{font-size:1.15rem;font-weight:800;margin:30px 0 14px}
.chip-alergia{display:inline-block;background:var(--vermelho-claro);color:#c0383c;padding:2px 9px;border-radius:6px;font-size:.8rem;font-weight:700;margin:2px}
.rodape{text-align:center;color:var(--texto-suave);font-size:.85rem;padding:24px;border-top:1px solid var(--borda);background:var(--branco)}
.timer{font-variant-numeric:tabular-nums;font-weight:800;color:var(--azul)}
.barra-progresso{height:8px;background:var(--fundo);border-radius:6px;overflow:hidden;margin-top:8px}
.barra-progresso span{display:block;height:100%;background:var(--azul);border-radius:6px}
.print-only{display:none}

/* ---------- RESPONSIVO ---------- */
@media(max-width:820px){
  .menu-toggle{display:block;order:3}
  .nav{display:none;width:100%;flex-direction:column;align-items:stretch;gap:2px;margin-top:8px}
  .nav.aberto{display:flex}
  .nav a{padding:11px 14px}
}
@media print{
  .topo,.rodape,.no-print,.btn{display:none!important}
  .print-only{display:block}
  body{background:#fff}
  .conteudo{padding:0;max-width:100%}
  .card,.tabela-wrap{box-shadow:none;border:1px solid #ccc}
}
