/* ============================================================
   Sistema de Produção ADE — identidade visual
   Azul-marinho #0d1626 / Azul royal #1f6fff / fundo claro
   ============================================================ */
:root{
  --marinho:#0d1626;
  --marinho-2:#142136;
  --royal:#1f6fff;
  --royal-escuro:#1657d6;
  --claro:#f4f6fb;
  --branco:#ffffff;
  --borda:#e2e7f0;
  --texto:#1a2233;
  --suave:#6b7280;
  /* cores de status da arte (semáforo) */
  --st-aenviar:#6b7280;
  --st-cliente:#7c3aed;
  --st-enviada:#2563eb;
  --st-aprovada:#16a34a;
  --st-alteracao:#ea580c;
  --st-critico:#dc2626;
  --st-cancelado:#374151;
  --alerta-bg:#fff4f4;
  --alerta-borda:#f3b4b4;
}
*{box-sizing:border-box}
body{
  margin:0;font-family:'Segoe UI',system-ui,-apple-system,Arial,sans-serif;
  background:var(--claro);color:var(--texto);font-size:15px;
}
a{color:var(--royal);text-decoration:none}

/* ---------- Cabeçalho ---------- */
.topo{
  background:var(--marinho);color:#fff;display:flex;align-items:center;
  justify-content:space-between;padding:10px 22px;gap:16px;
  box-shadow:0 2px 8px rgba(13,22,38,.18);
}
.topo .logo img{height:34px;display:block}
.topo .user{display:flex;align-items:center;gap:14px;font-size:14px}
.topo .user .nome{opacity:.85}
.btn-sair{
  color:#fff;border:1px solid rgba(255,255,255,.35);padding:5px 12px;
  border-radius:7px;font-size:13px;transition:.15s;
}
.btn-sair:hover{background:rgba(255,255,255,.12)}

/* ---------- Container ---------- */
.wrap{max-width:1180px;margin:0 auto;padding:22px}

/* ---------- Botões ---------- */
.btn{
  display:inline-block;background:var(--royal);color:#fff;border:0;
  padding:10px 18px;border-radius:9px;font-weight:600;cursor:pointer;
  font-size:14px;transition:.15s;
}
.btn:hover{background:var(--royal-escuro)}
.btn.secund{background:#fff;color:var(--royal);border:1px solid var(--borda)}
.btn.secund:hover{background:var(--claro)}

/* ---------- Cards / barras ---------- */
.card{background:#fff;border:1px solid var(--borda);border-radius:14px;padding:20px}
.resumo{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.kpi{
  background:#fff;border:1px solid var(--borda);border-radius:14px;
  padding:14px 18px;min-width:150px;flex:1;
}
.kpi .rotulo{font-size:12px;color:var(--suave);text-transform:uppercase;letter-spacing:.4px}
.kpi .valor{font-size:24px;font-weight:700;margin-top:4px}
.kpi.receita .valor{color:var(--st-aprovada)}
.kpi.alerta .valor{color:var(--st-critico)}

/* ---------- Tabela de pedidos ---------- */
.barra-data{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.barra-data select,.barra-data input[type=date]{
  padding:9px 12px;border:1px solid var(--borda);border-radius:9px;font-size:14px;background:#fff;
}
table.pedidos{width:100%;border-collapse:collapse;background:#fff;
  border:1px solid var(--borda);border-radius:14px;overflow:hidden}
table.pedidos th,table.pedidos td{padding:6px 12px;text-align:left;font-size:14px;
  border-bottom:1px solid var(--borda);vertical-align:middle}
table.pedidos th{background:var(--marinho-2);color:#fff;font-weight:600;
  font-size:12px;text-transform:uppercase;letter-spacing:.3px}
table.pedidos th.ord{cursor:pointer;user-select:none;white-space:nowrap}
table.pedidos th.ord:hover{background:#1d3050}
th.ord .seta::after{content:"\2195";opacity:.4;margin-left:4px;font-size:11px}
th.ord.asc .seta::after{content:"\2191";opacity:1}
th.ord.desc .seta::after{content:"\2193";opacity:1}
/* zebra: branco x branco-gelo */
table.pedidos tbody tr:nth-child(even) td{background:#f7f9fc}
table.pedidos tr:last-child td{border-bottom:0}
table.pedidos tbody tr:hover td{background:#eef3ff}

/* botão copiar ID */
.cel-id{display:flex;align-items:center;gap:8px}
.btn-copiar{border:1px solid var(--borda);background:#fff;color:var(--royal);
  cursor:pointer;border-radius:6px;width:24px;height:24px;font-size:13px;line-height:1;
  padding:0;transition:.12s}
.btn-copiar:hover{background:var(--royal);color:#fff}
.btn-copiar.copiado{background:var(--st-aprovada);color:#fff;border-color:var(--st-aprovada)}

/* campo de anotação manual */
.anotacao{width:100%;min-width:120px;padding:5px 8px;border:1px solid var(--borda);
  border-radius:7px;font-size:13px;background:#fff}
.anotacao:focus{outline:none;border-color:var(--royal);box-shadow:0 0 0 2px rgba(31,111,255,.15)}
.anotacao.salvo{border-color:var(--st-aprovada);background:#f0fbf4}
.anotacao.erro-salvar{border-color:var(--st-critico)}
.cel-obs{max-width:220px;white-space:normal;color:var(--suave);font-size:13px}

/* contadores por status (cards coloridos) */
.resumo-status{margin-top:-6px}
.kpi-status{color:#fff;border:0}
.kpi-status .rotulo{color:rgba(255,255,255,.9)}
.kpi-status .valor{color:#fff}
.qtd-total{font-weight:700;font-size:15px}
.qtd-detalhe{color:var(--suave);font-size:12px}

/* linha que precisa de revisão */
tr.revisar td{background:var(--alerta-bg)!important}
tr.revisar td:first-child{box-shadow:inset 4px 0 0 var(--st-critico)}
.tag-revisar{background:var(--st-critico);color:#fff;font-size:11px;font-weight:700;
  padding:2px 8px;border-radius:20px;white-space:nowrap}

/* select de status colorido (com seta visível) */
.status-sel{padding:5px 26px 5px 10px;border-radius:8px;border:1px solid rgba(0,0,0,.08);
  font-size:13px;font-weight:600;color:#fff;cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='white' stroke-width='1.6' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 8px center}
.filtro-status{padding:9px 12px;border:1px solid var(--borda);border-radius:9px;
  font-size:14px;background:#fff;cursor:pointer}
.st-A.enviar,.status-A\.enviar{}
.status--aenviar{background:var(--st-aenviar)}
.status--cliente{background:var(--st-cliente)}
.status--enviada{background:var(--st-enviada)}
.status--aprovada{background:var(--st-aprovada)}
.status--alteracao{background:var(--st-alteracao)}
.status--critico{background:var(--st-critico)}
.status--cancelado{background:var(--st-cancelado)}

/* ---------- Contador de alterações ---------- */
.alt-wrap{display:flex;align-items:center;gap:6px}
.alt-dots{display:inline-flex;gap:4px;align-items:center}
.alt-dot{width:12px;height:12px;border-radius:50%;border:1.5px solid var(--borda);
  background:#fff;cursor:pointer;transition:.15s;padding:0}
.alt-dot:hover{border-color:var(--st-alteracao)}
.alt-dot.used{background:var(--st-critico);border-color:var(--st-critico)}
.alt-limite{font-size:10px;color:var(--st-critico);font-weight:700;white-space:nowrap}

/* ---------- Modal cancelamento ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(13,22,38,.55);z-index:9998;
  display:flex;align-items:center;justify-content:center}
.modal-box{background:#fff;border-radius:16px;padding:24px 28px;width:520px;max-width:92vw;
  max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.radio-card{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;
  border:1px solid var(--borda);border-radius:9px;cursor:pointer;font-size:14px;font-weight:600;
  transition:.15s}
.radio-card:has(input:checked){background:var(--royal);color:#fff;border-color:var(--royal)}
.radio-card input{display:none}
.chk-cat{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;
  border:1px solid var(--borda);border-radius:20px;cursor:pointer;font-size:13px;transition:.15s}
.chk-cat:has(input:checked){background:var(--st-critico);color:#fff;border-color:var(--st-critico)}
.chk-cat input{display:none}

/* ---------- Login ---------- */
.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--marinho),var(--marinho-2))}
.login-card{background:#fff;border-radius:18px;padding:36px 34px;width:360px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);text-align:center}
.login-card img.logo-login{height:42px;margin-bottom:6px}
.login-card .sub{color:var(--suave);font-size:13px;margin-bottom:22px}
.login-card label{display:block;text-align:left;font-size:13px;font-weight:600;
  margin:12px 0 5px}
.login-card input{width:100%;padding:11px 13px;border:1px solid var(--borda);
  border-radius:10px;font-size:15px}
.login-card .btn{width:100%;margin-top:20px;padding:12px}
.erro{background:var(--alerta-bg);border:1px solid var(--alerta-borda);
  color:var(--st-critico);padding:10px;border-radius:10px;font-size:13px;margin-top:14px}
.aviso{background:#eef4ff;border:1px solid #cfe0ff;color:var(--royal-escuro);
  padding:12px 14px;border-radius:11px;font-size:14px;margin-bottom:16px}

/* formulário de pedido manual */
.campo{margin-bottom:14px}
.campo label{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.campo input,.campo-sel{width:100%;padding:10px 12px;border:1px solid var(--borda);
  border-radius:10px;font-size:14px;background:#fff}
.campo input:focus,.campo-sel:focus{outline:none;border-color:var(--royal);
  box-shadow:0 0 0 2px rgba(31,111,255,.15)}
.linha-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.linha-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media(max-width:560px){.linha-2,.linha-3{grid-template-columns:1fr}}

/* upload */
.dropzone{border:2px dashed #c7d2e8;border-radius:14px;padding:30px;text-align:center;
  background:#fff;color:var(--suave)}
.rodape-sistema{text-align:center;color:var(--suave);font-size:12px;padding:24px;
  display:flex;align-items:center;justify-content:center;gap:8px}
.rodape-sistema img{height:26px;opacity:.8}

/* ---------- Hub ---------- */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;max-width:720px;margin:40px auto}
.hub-card{background:#fff;border:1px solid var(--borda);border-radius:16px;padding:32px 24px;
  text-align:center;transition:.2s;cursor:pointer;text-decoration:none;color:var(--texto)}
.hub-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(13,22,38,.12);border-color:var(--royal)}
.hub-card .hub-icone{font-size:36px;margin-bottom:10px}
.hub-card .hub-titulo{font-size:18px;font-weight:700;margin-bottom:6px}
.hub-card .hub-desc{font-size:13px;color:var(--suave)}

/* ---------- Notificação toast ---------- */
.toast-container{position:fixed;top:70px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 18px;border-radius:10px;color:#fff;font-size:14px;font-weight:600;
  box-shadow:0 4px 16px rgba(0,0,0,.2);animation:toastIn .3s ease;max-width:360px}
.toast--critico{background:var(--st-critico)}
.toast--cancelado{background:var(--st-cancelado)}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ---------- Checkbox selecionar IDs ---------- */
.chk-id{width:16px;height:16px;cursor:pointer;accent-color:var(--royal)}
.barra-selecao{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:8px 14px;
  background:#fff;border:1px solid var(--borda);border-radius:10px}
.barra-selecao .cont{font-size:14px;color:var(--suave)}

/* ---------- Status option colors ---------- */
.status-sel option{color:#fff;font-weight:600;padding:4px 8px}
.status-sel option[value="A enviar"]{background:var(--st-aenviar)}
.status-sel option[value="Arte Enviada"]{background:var(--st-enviada)}
.status-sel option[value="Arte do Cliente"]{background:var(--st-cliente)}
.status-sel option[value="Aprovada"]{background:var(--st-aprovada)}
.status-sel option[value="Alteração"]{background:var(--st-alteracao)}
.status-sel option[value="Caso Crítico"]{background:var(--st-critico)}
.status-sel option[value="Cancelado"]{background:var(--st-cancelado)}

@media(max-width:640px){
  .wrap{padding:14px}
  table.pedidos{display:block;overflow-x:auto;white-space:nowrap}
}
