/* ===================================================================
   lab.vouz.tec.br — estilo.css
   Design limpo, claro e responsivo (mobile-first). Sem framework.
   =================================================================== */

:root{
  --bg:        #f4f6fb;
  --surface:   #ffffff;
  --texto:     #1f2937;
  --muted:     #6b7280;
  --borda:     #e5e7eb;
  --primaria:      #5b5bf0;
  --primaria-esc:  #4847d4;
  --sucesso:   #15803d;
  --sucesso-bg:#dcfce7;
  --erro:      #b91c1c;
  --erro-bg:   #fee2e2;
  --aviso:     #b45309;
  --aviso-bg:  #fef3c7;
  --raio:      14px;
  --raio-sm:   9px;
  --sombra:    0 1px 2px rgba(16,24,40,.06), 0 8px 24px rgba(16,24,40,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);
  color:var(--texto);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primaria);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
h1{font-size:1.6rem;margin:0 0 .4rem}
h2{font-size:1.25rem}
.muted{color:var(--muted)}
code{background:#eef0f6;padding:1px 6px;border-radius:6px;font-size:.9em}

/* ── Barra superior ───────────────────────────────────────────── */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px 20px;background:var(--surface);
  border-bottom:1px solid var(--borda);position:sticky;top:0;z-index:20;
}
.logo{font-weight:800;font-size:1.2rem;color:var(--texto)}
.logo span{color:var(--primaria)}
.logo:hover{text-decoration:none}
.topnav{display:flex;align-items:center;gap:18px}
.topnav a{color:var(--texto);font-weight:600;font-size:.95rem}
.form-inline{display:inline;margin:0}
.link-btn{background:none;border:none;color:var(--texto);font:inherit;
  font-weight:600;cursor:pointer;padding:0}
.link-btn:hover{color:var(--primaria)}
.badge-noti{display:inline-block;min-width:18px;height:18px;line-height:18px;
  text-align:center;background:var(--erro);color:#fff;border-radius:999px;
  font-size:.72rem;font-weight:700;padding:0 5px;margin-left:4px}

/* ── Conteúdo / rodapé ────────────────────────────────────────── */
.conteudo{max-width:1040px;margin:0 auto;padding:24px 18px 48px}
.rodape{text-align:center;color:var(--muted);font-size:.9rem;padding:28px 16px}

/* ── Botões ───────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1px solid var(--borda);background:var(--surface);color:var(--texto);
  padding:10px 16px;border-radius:var(--raio-sm);font-weight:600;font-size:.95rem;
  cursor:pointer;transition:filter .15s,transform .02s;text-decoration:none;
}
.btn:hover{filter:brightness(.98);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primaria);border-color:var(--primaria);color:#fff}
.btn-primary:hover{background:var(--primaria-esc)}
.btn-perigo{background:var(--erro);border-color:var(--erro);color:#fff}
.btn-perigo:hover{filter:brightness(1.05)}
.btn-secundario{background:#eef0f6;border-color:#e2e6f0}
.btn-bloco{width:100%}
.btn-sm{padding:6px 12px;font-size:.85rem}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ── Formulários ──────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:14px}
.campo{display:flex;flex-direction:column;gap:6px}
.campo label{font-weight:600;font-size:.92rem}
.campo input,.campo textarea,.campo select{
  width:100%;padding:11px 12px;border:1px solid var(--borda);
  border-radius:var(--raio-sm);font:inherit;background:#fff;color:var(--texto);
}
.campo input:focus,.campo textarea:focus,.campo select:focus{
  outline:none;border-color:var(--primaria);box-shadow:0 0 0 3px rgba(91,91,240,.15);
}
.ajuda{color:var(--muted);font-size:.82rem}

/* ── Cartão de autenticação ───────────────────────────────────── */
.auth-card{
  max-width:430px;margin:36px auto;background:var(--surface);
  border:1px solid var(--borda);border-radius:var(--raio);
  box-shadow:var(--sombra);padding:28px;
}
.auth-links{display:flex;justify-content:space-between;gap:12px;
  margin-top:18px;font-size:.9rem;flex-wrap:wrap}

/* ── Mensagens flash ──────────────────────────────────────────── */
.flash{padding:12px 14px;border-radius:var(--raio-sm);margin:0 0 14px;
  font-size:.95rem;cursor:pointer;border:1px solid transparent}
.flash-sucesso{background:var(--sucesso-bg);color:var(--sucesso);border-color:#bbf7d0}
.flash-erro{background:var(--erro-bg);color:var(--erro);border-color:#fecaca}
.flash-aviso{background:var(--aviso-bg);color:var(--aviso);border-color:#fde68a}

/* ── Caixa de aviso ───────────────────────────────────────────── */
.aviso{background:var(--aviso-bg);color:var(--aviso);border:1px solid #fde68a;
  border-radius:var(--raio-sm);padding:12px 14px;font-size:.92rem}

/* ── Cabeçalho de página ──────────────────────────────────────── */
.pagina-cab{display:flex;align-items:center;justify-content:space-between;
  gap:16px;margin-bottom:20px;flex-wrap:wrap}

/* ── Grade de cartões (galeria / meus projetos) ───────────────── */
.grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.cartao{background:var(--surface);border:1px solid var(--borda);
  border-radius:var(--raio);box-shadow:var(--sombra);padding:18px;
  display:flex;flex-direction:column;gap:10px}
.cartao h3{margin:0;font-size:1.05rem}
.cartao .acoes{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:8px}

/* ── Selos (badges) ───────────────────────────────────────────── */
.selo{display:inline-block;font-size:.72rem;font-weight:700;padding:3px 9px;
  border-radius:999px;text-transform:uppercase;letter-spacing:.02em}
.selo-publico{background:#dcfce7;color:#15803d}
.selo-privado{background:#e5e7eb;color:#4b5563}
.selo-editor{background:#e0e7ff;color:#4338ca}
.selo-upload{background:#fae8ff;color:#a21caf}
.selos{display:flex;gap:6px;flex-wrap:wrap}

/* ── Estado vazio ─────────────────────────────────────────────── */
.vazio{text-align:center;background:var(--surface);border:1px dashed var(--borda);
  border-radius:var(--raio);padding:48px 24px;color:var(--muted)}
.vazio h2{color:var(--texto);margin-bottom:6px}

/* ── Tabela (admin) ───────────────────────────────────────────── */
.tabela-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--borda);
  border-radius:var(--raio);box-shadow:var(--sombra)}
table.tabela{width:100%;border-collapse:collapse;font-size:.92rem}
table.tabela th,table.tabela td{padding:11px 14px;text-align:left;
  border-bottom:1px solid var(--borda);white-space:nowrap}
table.tabela th{background:#f8fafc;font-weight:700}
table.tabela tr:last-child td{border-bottom:none}

/* ── Métricas (dashboard) ─────────────────────────────────────── */
.metricas{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:24px}
.metrica{background:var(--surface);border:1px solid var(--borda);border-radius:var(--raio);
  box-shadow:var(--sombra);padding:18px}
.metrica .num{font-size:2rem;font-weight:800;line-height:1}
.metrica .rot{color:var(--muted);font-size:.85rem;margin-top:4px}

/* ── Abas do editor ───────────────────────────────────────────── */
.abas{display:flex;gap:4px;border-bottom:1px solid var(--borda);margin-bottom:0}
.aba{padding:10px 16px;border:1px solid transparent;border-bottom:none;
  background:none;font:inherit;font-weight:600;cursor:pointer;color:var(--muted);
  border-radius:var(--raio-sm) var(--raio-sm) 0 0}
.aba.ativa{background:var(--surface);color:var(--texto);border-color:var(--borda)}
.editor-area{display:none;width:100%;min-height:320px;padding:14px;
  border:1px solid var(--borda);border-top:none;font-family:ui-monospace,
  SFMono-Regular,Menlo,Consolas,monospace;font-size:.9rem;resize:vertical}
.editor-area.ativa{display:block}
.preview-frame{width:100%;height:420px;border:1px solid var(--borda);
  border-radius:var(--raio-sm);background:#fff}

/* ── Modal de confirmação ─────────────────────────────────────── */
.modal-fundo{position:fixed;inset:0;background:rgba(15,23,42,.55);
  display:none;align-items:center;justify-content:center;z-index:50;padding:18px}
.modal-fundo.aberto{display:flex}
.modal{background:#fff;border-radius:var(--raio);max-width:420px;width:100%;
  padding:24px;box-shadow:var(--sombra)}
.modal h3{margin-top:0}
.modal .acoes{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

/* ── Área de upload (arrastar e soltar) ───────────────────────── */
.dropzone{border:2px dashed #c7ccdb;border-radius:var(--raio);padding:38px 20px;
  text-align:center;color:var(--muted);background:var(--surface);cursor:pointer;
  transition:border-color .15s,background .15s}
.dropzone.sobre{border-color:var(--primaria);background:#f5f5ff}

/* ── Wrapper do projeto ao vivo (/u/...) ──────────────────────── */
.uframe{width:100%;height:calc(100vh - 58px);border:none;display:block;background:#fff}
.ubar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 18px;background:var(--surface);border-bottom:1px solid var(--borda)}

/* ── Sub-navegação do admin ───────────────────────────────────── */
.adminnav{display:flex;gap:6px;flex-wrap:wrap;background:var(--surface);
  border:1px solid var(--borda);border-radius:var(--raio);padding:8px;
  margin-bottom:20px;box-shadow:var(--sombra)}
.adminnav a{padding:8px 14px;border-radius:var(--raio-sm);color:var(--texto);
  font-weight:600;font-size:.92rem}
.adminnav a:hover{background:#f1f3f9;text-decoration:none}
.adminnav a.ativo{background:var(--primaria);color:#fff}

/* ── Filtros / linha de ações em tabela ───────────────────────── */
.filtros{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.acoes-linha{display:flex;gap:6px;flex-wrap:wrap}
.form-inline-tbl{display:inline}

/* ── Toasts (feedback flutuante) ──────────────────────────────── */
.toasts{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;
  gap:8px;z-index:60;max-width:320px}
.toasts .flash{margin:0;box-shadow:var(--sombra);transition:opacity .3s}

/* ── Tela "novo projeto" (escolha editor x upload) ────────────── */
.opcoes-novo{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.opcao{display:block;background:var(--surface);border:1px solid var(--borda);
  border-radius:var(--raio);box-shadow:var(--sombra);padding:28px;text-align:center;color:var(--texto)}
.opcao:hover{text-decoration:none;border-color:var(--primaria);transform:translateY(-2px);transition:.15s}
.opcao .ic{font-size:2.6rem;line-height:1}
.opcao h3{margin:.5rem 0 .25rem}

/* ── Blocos e linhas de formulário ────────────────────────────── */
.bloco{background:var(--surface);border:1px solid var(--borda);border-radius:var(--raio);
  box-shadow:var(--sombra);padding:18px;margin-bottom:18px}
.linha{display:flex;gap:12px;flex-wrap:wrap}
.linha .campo{flex:1;min-width:180px}

/* ── Editor: layout em duas colunas no desktop ────────────────── */
.editor-grid{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:920px){.editor-grid{grid-template-columns:1fr 1fr}}
.nome-arquivo{margin-top:10px;font-weight:600}

@media (max-width:520px){
  .topnav{gap:12px}
  .auth-links{flex-direction:column;text-align:center}
}
