*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--fonte-corpo);color:var(--tinta);background:var(--fundo-alt);line-height:1.5}
h1,h2,h3,h4{font-family:var(--fonte-titulo);line-height:1.2;margin:0 0 .4em}
a{color:var(--azul);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.skip{position:absolute;left:-999px}
.skip:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:99}

/* ─── topo ─── */
.govbar{background:var(--azul-escuro);color:#dbe7f2;font-size:13px}
.govbar .container{display:flex;justify-content:space-between;align-items:center;height:34px;gap:12px}
.govbar a{color:#dbe7f2}
.header{background:#fff;border-bottom:1px solid var(--linha)}
.header .container{display:flex;align-items:center;gap:16px;min-height:74px;padding-top:10px;padding-bottom:10px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;color:var(--tinta)}
.brand:hover{text-decoration:none}
.brand__bras{width:46px;height:46px;object-fit:contain}
.brand__txt strong{display:block;font-family:var(--fonte-titulo);font-size:18px;color:var(--verde-escuro)}
.brand__txt span{font-size:12.5px;color:var(--cinza)}
.brand__mark{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:10px;background:var(--verde);color:#fff;font-family:var(--fonte-titulo);font-weight:800;font-size:20px}
.topo-acoes{margin-left:auto;display:flex;align-items:center;gap:10px;font-size:14px}
.nav{background:var(--verde);}
.nav .container{display:flex;gap:4px;flex-wrap:wrap}
.nav a{color:#eafbf1;padding:12px 14px;font-weight:600;font-size:14.5px}
.nav a:hover,.nav a[aria-current=page]{background:var(--verde-escuro);text-decoration:none}

/* ─── botões ─── */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid transparent;border-radius:var(--raio-sm);
  padding:9px 15px;font:inherit;font-weight:600;font-size:14px;cursor:pointer;background:var(--verde);color:#fff;transition:.15s}
.btn:hover{background:var(--verde-escuro);text-decoration:none}
.btn--sec{background:#fff;color:var(--azul);border-color:var(--linha)}
.btn--sec:hover{background:var(--fundo-alt)}
.btn--peq{padding:5px 10px;font-size:13px}
.btn--ok{background:var(--st-ok)} .btn--rej{background:var(--st-rej)}
.btn--rej:hover{background:#9c2c20}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ─── cartões / layout ─── */
main{padding:26px 0 60px}
.card{background:#fff;border:1px solid var(--linha);border-radius:var(--raio);box-shadow:var(--sombra)}
.card__b{padding:18px 20px}
.grid{display:grid;gap:18px}
.grid--2{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.pagehead{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.pagehead h1{margin:0;font-size:26px;color:var(--verde-escuro)}
.muted{color:var(--cinza);font-size:14px}
.crumbs{font-size:13px;color:var(--cinza);margin-bottom:6px}

/* ─── tabela ─── */
table.tab{width:100%;border-collapse:collapse;font-size:14px;background:#fff}
.tab th,.tab td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--linha);vertical-align:middle}
.tab th{font-family:var(--fonte-titulo);font-size:12.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--cinza);background:var(--fundo-alt)}
.tab tr:hover td{background:#fafdfb}

/* ─── badges/status ─── */
.badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}
.b-em_andamento{background:var(--st-pend-bg);color:var(--st-pend)}
.b-aprovado{background:#e7f0fb;color:var(--azul)}
.b-registrado{background:var(--st-ok-bg);color:var(--st-ok)}
.b-indeferido,.b-suspenso{background:var(--st-rej-bg);color:var(--st-rej)}
.st{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:12.5px;padding:3px 9px;border-radius:999px}
.st::before{content:"";width:8px;height:8px;border-radius:50%}
.st-validado{background:var(--st-ok-bg);color:var(--st-ok)} .st-validado::before{background:var(--st-ok)}
.st-pendente{background:var(--st-pend-bg);color:var(--st-pend)} .st-pendente::before{background:var(--st-pend)}
.st-rejeitado{background:var(--st-rej-bg);color:var(--st-rej)} .st-rejeitado::before{background:var(--st-rej)}
.st-sem_doc{background:var(--st-vazio-bg);color:var(--st-vazio)} .st-sem_doc::before{background:var(--st-vazio)}
.pill{display:inline-block;background:var(--verde-claro);color:var(--verde-escuro);border-radius:6px;padding:2px 8px;font-size:12px;font-weight:600}

/* ─── progresso ─── */
.prog{height:9px;border-radius:999px;background:var(--linha);overflow:hidden}
.prog>i{display:block;height:100%;background:var(--verde);border-radius:999px}

/* ─── etapas / checklist ─── */
.etapa{border:1px solid var(--linha);border-radius:var(--raio);background:#fff;margin-bottom:14px;overflow:hidden}
.etapa__h{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--fundo-alt);border-bottom:1px solid var(--linha)}
.etapa__h h3{margin:0;font-size:16px}
.etapa__pct{margin-left:auto;font-weight:800;color:var(--verde-escuro);font-size:14px;min-width:46px;text-align:right}
.etapa__h .prog{flex:1;max-width:200px}
.doc{display:flex;align-items:center;gap:12px;padding:11px 18px;border-bottom:1px solid var(--linha);flex-wrap:wrap}
.doc:last-child{border-bottom:0}
.doc__cod{font-family:var(--fonte-titulo);font-weight:700;color:var(--cinza);font-size:13px;min-width:46px}
.doc__nome{flex:1;min-width:200px}
.doc__nome small{display:block;color:var(--cinza-claro);font-size:12px;margin-top:1px}
.doc__acoes{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.cond{font-size:11px;color:var(--dourado);font-weight:700;border:1px solid var(--dourado);border-radius:5px;padding:0 5px;margin-left:6px}
.arq{font-size:13px;display:flex;align-items:center;gap:8px;padding:4px 0}
.arq a{font-weight:600}

/* ─── timeline ─── */
.tl{list-style:none;margin:0;padding:0}
.tl li{position:relative;padding:0 0 14px 22px;border-left:2px solid var(--linha);margin-left:6px}
.tl li::before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--verde);border:2px solid #fff}
.tl time{font-size:12px;color:var(--cinza-claro);display:block}

/* ─── formulários ─── */
label{display:block;font-size:13px;font-weight:600;margin:10px 0 4px}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--linha);border-radius:var(--raio-sm);font:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid var(--azul);border-color:var(--azul)}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>div{flex:1;min-width:160px}
.aviso{background:var(--st-rej-bg);color:var(--st-rej);padding:9px 12px;border-radius:var(--raio-sm);font-size:13.5px;margin:8px 0}
.ok-box{background:var(--verde-claro);color:var(--verde-escuro);padding:9px 12px;border-radius:var(--raio-sm);font-size:13.5px;margin:8px 0}

/* ─── filtros públicos ─── */
.filtros{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:18px}
.filtros>div{min-width:170px}
.filtros label{margin-top:0}

/* ─── modal ─── */
dialog{border:0;border-radius:var(--raio);box-shadow:0 20px 60px rgba(0,0,0,.3);padding:0;max-width:520px;width:92vw}
dialog::backdrop{background:rgba(15,40,30,.45)}
.modal__h{padding:16px 20px;border-bottom:1px solid var(--linha);font-family:var(--fonte-titulo);font-weight:700}
.modal__b{padding:18px 20px}
.modal__f{padding:14px 20px;border-top:1px solid var(--linha);display:flex;justify-content:flex-end;gap:8px}

/* ─── login ─── */
.login-wrap{max-width:400px;margin:50px auto}

/* ─── rodapé ─── */
.footer{background:var(--azul-escuro);color:#cdddea;font-size:13.5px;padding:22px 0;margin-top:40px}
.footer a{color:#fff}
.footer .container{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

@media(max-width:640px){
  .pagehead h1{font-size:22px}
  .etapa__h{flex-wrap:wrap}
  .etapa__h .prog{order:3;max-width:none;width:100%}
}

/* ─── impressão do relatório ─── */
@media print{
  .govbar,.header,.nav,.footer,.no-print{display:none!important}
  body{background:#fff}
  main{padding:0}
  .etapa,.card{box-shadow:none;break-inside:avoid}
}
