:root { --cor-primaria: #1d6fb8; }
* { box-sizing: border-box; }
body { margin: 0; font-family: -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
       background: #f3f5f8; color: #1f2933; }

/* ---- Topo (white-label) ---- */
.topo { background: var(--cor-primaria); color: #fff; display: flex;
        align-items: center; justify-content: space-between; padding: 10px 18px;
        flex-wrap: wrap; gap: 10px; }
.topo-marca { display: flex; align-items: center; gap: 10px; }
.logo { height: 38px; width: auto; background:#fff; border-radius:4px; padding:2px; }
.nome-empresa { font-weight: 700; font-size: 16px; }
.menu { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.menu a { color: #fff; text-decoration: none; font-size: 14px; opacity: .92; }
.menu a:hover { opacity: 1; text-decoration: underline; }
.menu .usuario { font-size: 13px; opacity: .8; }
.menu .sair { background: rgba(255,255,255,.18); padding: 4px 10px; border-radius: 4px; }

.conteudo { max-width: 980px; margin: 22px auto; padding: 0 18px; }
.cabecalho-pagina { display: flex; align-items: center; justify-content: space-between; }
h2 { color: #123a5c; }

/* ---- Botoes ---- */
.btn { background: var(--cor-primaria); color: #fff; border: none; padding: 9px 16px;
       border-radius: 6px; text-decoration: none; font-size: 14px; cursor: pointer;
       display: inline-block; }
.btn:hover { filter: brightness(.93); }
.btn-sec { background: #5a7184; }

/* ---- Tabelas ---- */
.tabela { width: 100%; border-collapse: collapse; margin-top: 14px; background: #fff;
          border-radius: 8px; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.tabela th { background: #123a5c; color: #fff; text-align: left; padding: 10px; font-size: 13px; }
.tabela td { padding: 10px; border-top: 1px solid #eef1f4; font-size: 14px; }
.tabela tr.baixo td { background: #fff4f4; }
.vazio { text-align: center; color: #94a2ad; }

/* ---- Status ---- */
.badge-status { padding: 3px 9px; border-radius: 12px; font-size: 12px; color: #fff; }
.st-aberta { background:#5a7184; } .st-em_analise { background:#1d6fb8; }
.st-aguardando_peca { background:#e0a32e; } .st-aprovada { background:#7b68ee; }
.st-concluida { background:#0d8a5f; } .st-entregue { background:#0a6e4d; }
.st-cancelada { background:#b94a4a; }

/* ---- Filtros ---- */
.filtros { margin-top: 12px; display: flex; gap: 6px; flex-wrap: wrap; }
.filtros a { padding: 5px 11px; background: #fff; border: 1px solid #d6dee6;
             border-radius: 14px; text-decoration: none; color: #50606e; font-size: 13px; }
.filtros a.ativo { background: var(--cor-primaria); color: #fff; border-color: transparent; }

/* ---- Formularios ---- */
.form-vert { display: flex; flex-direction: column; gap: 12px; max-width: 620px; margin-top: 14px; }
.form-vert label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; color: #50606e; }
.form-vert input, .form-vert select, .form-vert textarea,
.form-inline input { padding: 9px; border: 1px solid #cdd7e0; border-radius: 6px; font-size: 14px; }
.form-inline { display: flex; gap: 8px; flex-wrap: wrap; margin: 14px 0; align-items: center; }
.linha-campos { display: flex; gap: 10px; flex-wrap: wrap; }
.linha-campos label { flex: 1; min-width: 120px; }
fieldset { border: 1px solid #dde3ea; border-radius: 8px; padding: 14px; }
legend { color: #123a5c; font-weight: 600; padding: 0 6px; }
.logo-preview, .logo-login { max-height: 70px; border-radius: 6px; }
.ajuda { color: #50606e; font-size: 13px; }

/* ---- Login ---- */
.card-login { max-width: 360px; margin: 60px auto; background: #fff; padding: 30px;
              border-radius: 10px; box-shadow: 0 4px 16px rgba(0,0,0,.08); text-align: center; }
.card-login form { display: flex; flex-direction: column; gap: 12px; margin-top: 16px; }
.card-login input { padding: 11px; border: 1px solid #cdd7e0; border-radius: 6px; }
.card-login button { background: var(--cor-primaria); color: #fff; border: none;
                     padding: 11px; border-radius: 6px; font-size: 15px; cursor: pointer; }

/* ---- Flash ---- */
.flash { padding: 10px 14px; border-radius: 6px; margin-bottom: 12px; font-size: 14px; }
.flash-ok { background: #e3f6ec; color: #0a6e4d; }
.flash-erro { background: #fdecec; color: #b03030; }
