/* ======== BASE ======== */
:root {
  --bg:#f6f7fb;
  --card:#fff;
  --text:#1f2937;
  --muted:#6b7280;
  --line:#e5e7eb;

  /* Ajuste de cores para maior profissionalismo */
  --primary:#1E3A8A;      /* Azul corporativo mais escuro */
  --primary-700:#1C3371;  /* Azul ainda mais escuro para hover */
  --accent:#374151;       /* Mantém o cinza-escuro para os th */
  
  /* menu */
  --nav-font:13px;
  --nav-brand:16px;
}
*{box-sizing:border-box}
html,body{height:100%}
th:first-child {
  border-top-left-radius: 6px;
}
th:last-child {
  border-top-right-radius: 6px;
}
th {
  padding: 8px 12px;
}
body{margin:0;background:var(--bg);color:var(--text);font:14px/1.45 system-ui,Segoe UI,Arial}

/* container principal da página */
#conteudo{
  max-width:1024px;margin:20px auto;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:16px;
  box-shadow:0 1px 2px rgba(0,0,0,.04)
}

/* ======== TIPOGRAFIA ======== */
.h-title{margin:0 0 6px;font-weight:700;font-size:20px;line-height:1.2}
.h-sub{margin:0 0 14px;color:var(--muted)}

/* ======== BREADCRUMB / ETAPAS ======== */
.breadcrumb{font-size:12px;color:var(--muted);margin:0 0 10px}
.breadcrumb strong{color:#111827}
.steps{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 12px}
.step{
  font-weight:600;font-size:12px;padding:6px 10px;border-radius:999px;
  border:1px solid var(--line);background:#fff;color:var(--muted)
}
.step.is-active{border-color:var(--primary);color:var(--primary)}
.step::before{content:attr(data-step) "º ";opacity:.7}

/* ======== CARDS / ALERTAS ======== */
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:12px}
.alert{border:1px solid var(--line);padding:10px 12px;border-radius:10px;margin:8px 0}
.alert.ok{background:var(--ok)} .alert.info{background:var(--info)} .alert.err{background:var(--err)}

/* ======== BOTÕES (padrão global) ======== */
button,
input[type="submit"],
input[type="button"],
input[type="reset"],
.btn, .bta {
  -webkit-appearance:none;
  appearance:none;
  background:var(--primary);
  color:#fff;
  border: 1px solid rgba(255,255,255,0.2); /* borda sutil */
  border-radius:10px;
  padding:10px 14px;
  font:600 14px/1 system-ui,Segoe UI,Arial;
  cursor:pointer;
  box-shadow:0 1px 0 rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.06);
  transition:background-color .15s ease, filter .15s ease, transform .02s ease;
  text-decoration:none;
  display:inline-block;
}
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
.btn:hover, .bta:hover {
  background: var(--primary-700);
  filter: brightness(1.05);
}
button:active, input[type="submit"]:active, input[type="button"]:active, input[type="reset"]:active, .btn:active, .bta:active{ transform:translateY(1px) }
button[disabled], input[disabled], .btn[aria-disabled="true"]{ opacity:.6; cursor:not-allowed }
.btn + .btn, button + button, input[type="submit"] + input[type="button"], input[type="button"] + input[type="button"]{ margin-left:6px }
.btn.secondary{ background:#111827 }
.btn.outline, button.outline{ background:#fff; color:var(--primary); border:1px solid var(--primary) }
.btn.danger,  button.danger{ background:#dc2626 }
.btn.small,   button.small{ padding:6px 10px; font-size:13px }
.btn.block,   button.block{ display:block; width:100%; text-align:center }

/* ======== FORM / TABELAS ======== */
input,select,textarea{
  font:13px system-ui,Segoe UI,Arial;color:#111827;background:#fff;
  border:1px solid var(--line);border-radius:8px;padding:8px 10px
}
input:focus,select:focus,textarea:focus{outline:2px solid #bfdbfe;border-color:#93c5fd}
table{width:100%;border-collapse:collapse}
th{background:var(--accent);color:#fff;font-weight:700}
th,td{padding:8px 10px;border-bottom:0px solid var(--line);text-align:left}
tr:hover td{background:#fafafa}

/* ======== NAV TOPBAR (SEM SETAS) ======== */
.topnav{background:#fff;border-bottom:1px solid var(--line)}
.topnav .nav-wrap{
  max-width:1024px;margin:0 auto;display:flex;align-items:center;
  gap:8px;padding:6px 8px
}
.topnav .brand{font-weight:800;font-size:var(--nav-brand)}
.topnav .brand a{color:var(--text);text-decoration:none}
.nav-links{list-style:none;display:flex;gap:6px;margin:0;padding:0}
.nav-link{
  padding:8px 12px;border-radius:8px;color:#111827;text-decoration:none;
  display:inline-block;font-size:var(--nav-font);line-height:1.2
}
.nav-link:hover,.nav-link.is-active{background:#eef2ff;color:#1d4ed8}
.nav-group{position:relative}
.nav-group .dropdown{
  display:none;position:absolute;top:36px;left:0;min-width:240px;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.08);
  padding:8px;z-index:10
}
.nav-group:hover .dropdown{display:block}
.dropdown a{display:block;padding:8px 10px;border-radius:8px;text-decoration:none;color:#111827;font-size:var(--nav-font)}
.dropdown a:hover{background:#f3f4f6}
.dropdown hr{border:0;border-top:1px solid var(--line);margin:6px 0}

/* Burger (mobile) */
#nav-toggle{display:none}
.burger{display:none;margin-left:auto;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:8px}
@media (max-width:840px){
  .burger{display:block}
  .nav-links{
    display:none;flex-direction:column;background:#fff;position:absolute;
    left:0;right:0;top:48px;border-bottom:1px solid var(--line);padding:8px
  }
  #nav-toggle:checked ~ .nav-links{display:flex}
  /* dropdown empilhado no mobile (sem hover) */
  .nav-group:hover .dropdown{display:none}
  .nav-group .dropdown{position:static;box-shadow:none;border:0;padding:0}
}
/* --- Dropdown colado no item (sem gap) --- */
.topnav .nav-group { position: relative; }

.topnav .nav-group .dropdown{
  top: 100%;       /* encosta logo abaixo do item */
  margin-top: 0;   /* garante zero de espaço */
}

/* Ponte anti-flicker (protege contra 1px de arredondamento) */
.topnav .nav-group::after{
  content:"";
  position:absolute;
  left:0; right:0;
  top:100%;
  height:6px;      /* “faixa” invisível entre o item e o dropdown */
}

/* opcional: se ainda notar “salto” em algum browser, use -1px */
@supports not (-webkit-touch-callout: none) { /* evita interferir em iOS */
  .topnav .nav-group .dropdown{ margin-top:-1px; } /* sobrepõe 1px no item */
}
/* === Setas nos grupos do menu (desktop) === */
.topnav .nav-group > a{
  position: relative;
  padding-right: 18px;                 /* espaço para a seta */
}

.topnav .nav-group > a::after{
  content:"";
  position:absolute;
  right: 8px;                          /* encosta à direita do item */
  top: 50%;
  width:0; height:0;                   /* triângulo via bordas */
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid #6b7280;       /* cor da seta (muted) */
  transform: translateY(-42%);         /* centraliza verticalmente */
  opacity:.75;
  transition: transform .15s ease, border-top-color .15s ease, opacity .15s ease;
}

.topnav .nav-group:hover > a::after{
  transform: translateY(-42%) rotate(180deg);
  border-top-color:#1d4ed8;            /* cor ativa (primary-700) */
  opacity:1;
}

/* No mobile, esconda a seta para não poluir o menu hamburguer */
@media (max-width:840px){
  .topnav .nav-group > a{ padding-right: 12px; }
  .topnav .nav-group > a::after{ display:none; }
}
/* Brand minimalista dentro do topnav */
.topnav .brand{display:flex;align-items:baseline;gap:10px}
.topnav .brand-logo{
  font-weight:900;font-size:22px;letter-spacing:.2px;
  color:var(--primary);text-decoration:none
}
.topnav .brand-tag{font-size:12px;color:var(--muted)}
@media (max-width:840px){ .topnav .brand-tag{display:none} }
/* --- Brand com logotipo --- */
.topnav .brand{display:flex;align-items:center;gap:10px}
.brand-logo-img{height:28px;width:auto;display:block}
.brand-wordmark{
  font-weight:900;font-size:20px;letter-spacing:.2px;
  color:var(--text);text-decoration:none
}
.topnav .brand-tag{font-size:12px;color:var(--muted)}
@media (max-width:840px){ .topnav .brand-tag{display:none} }
/* Brand com logotipo */
.topnav .brand{display:flex;align-items:center;gap:10px}
.brand-logo-img{height:28px;width:auto;display:block}
.brand-wordmark{
  font-weight:900;font-size:20px;letter-spacing:.2px;
  color:var(--text);text-decoration:none
}
.topnav .brand-tag{font-size:12px;color:var(--muted)}
@media (max-width:840px){ .topnav .brand-tag{display:none} }

img.logo {
  height: 50px;   /* ajuste aqui */
  width: auto;    /* mantém proporção */
}

nav ul li a {
    white-space: nowrap; /* impede quebra de linha */
}
 
 /* ======== HOME (painel inicial) ======== */
.wrap { max-width: 1100px; margin: 0 auto; padding: 16px; }
.hero { background: var(--bg); border-radius: 10px; padding: 16px 20px; margin: 8px 0 18px 0; }
.cards { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; }
.cardsleft { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; }
.card  { flex: 1 1 260px; max-width: 320px; border: 1px solid var(--line); border-radius: 12px; padding: 18px; text-align: center; background: var(--card); }
.card a { text-decoration: none; color: var(--text); display: block; }
.card strong { font-size: 18px; display: block; margin: 8px 0 4px; }
.card span { font-size: 13px; color: var(--muted); }
.mini { font-size: 12px; color: var(--muted); margin-top: 4px; }
.notice { border-left: 4px solid var(--primary); background: var(--info); padding: 8px 12px; border-radius: 6px; margin: 10px 0 18px; }
.grid2 { display:flex; gap:16px; flex-wrap:wrap; }
.grid2 > div { flex:1 1 320px; }
@media (max-width: 720px){
  .card { flex-basis: 100%; }
}
h1 {
	text-align: center !important;
	color: #333;
}





html, body {
  height: 100%;
  margin: 0;
  display: flex;
  flex-direction: column;
}

.wrap {
  flex: 1; /* faz o conteúdo ocupar o espaço disponível */
}

#rodape {
  background: var(--card);
  border-top: 1px solid var(--line);
  text-align: center;
  padding: 16px;
  color: var(--muted);
  font-size: 13px;
}
html { overflow-y: scroll; }  /* reserva sempre o espaço da barra */
/* estado normal não muda tamanho */
.topnav .nav-link { 
  border-bottom: 2px solid transparent;
}
/* ativo só troca a cor da borda */
.topnav .nav-link.is-active { 
  border-bottom-color: #0b5cff; 
  /* evite font-weight maior aqui; se quiser destaque, use cor */
}


/* === MELHORIA NO ESTILO DAS TABELAS === */
table {
  border-collapse: separate;   /* precisa para arredondar */
  border-spacing: 0;           /* remove espaçamento extra */
  border: 1px solid var(--line);
  border-radius: 6px;          /* cantos arredondados */
  overflow: hidden;            /* garante que o conteúdo siga o arredondamento */
}

th:first-child {
  border-top-left-radius: 6px;
}
th:last-child {
  border-top-right-radius: 6px;
}

td {
  border-bottom: 1px solid var(--line);
}

tr:last-child td {
  border-bottom: none;
}

th, td {
  border-left: 1px solid var(--line);
}
th:first-child, td:first-child {
  border-left: none;
}
/* Faixa azul com gradiente */
.bar-gradient {
  background: linear-gradient(90deg, #0D3B66, #205493);
  color: #fff;
}



==========================
  PATCH NO CSS (CstyleASP.css)
==========================
Cole no final do arquivo CstyleASP.css se quiser consolidar o CSS inline:

.wrap{max-width:1100px;margin:0 auto;padding:16px}
fieldset{border:1px solid var(--line);border-radius:10px;background:#f9fafb;padding:14px 16px;margin:12px 0}
legend{font-weight:700;color:var(--primary);padding:0 6px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.form-grid .full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column}
.form-group label{font-weight:600;margin:2px 0 4px}
.help{font-size:12px;color:var(--muted)}
@media (max-width:720px){ .form-grid{grid-template-columns:1fr} }
.actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}
.tablebox{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px}
.mini{font-size:12px;color:var(--muted)}
-->
