/* ===== Tokens ===== */
:root {
  --bg: #0b1020;
  --bg-2: #0f1530;
  --surface: #151c3a;
  --surface-2: #1b2348;
  --linha: #283163;
  --texto: #eef1ff;
  --texto-fraco: #9aa4d4;
  --accent: #5b8cff;
  --accent-2: #8b5bff;
  --ok: #38d39f;
  --aviso: #ffb454;
  --perigo: #ff5d6c;

  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --sombra: 0 10px 40px -12px rgba(0, 0, 0, .55);
  --sombra-fraca: 0 4px 18px -8px rgba(0, 0, 0, .5);
  --dur: 180ms;
  --ease: cubic-bezier(.16, 1, .3, 1);

  --fonte-titulo: 'Sora', system-ui, sans-serif;
  --fonte: 'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; }
/* garante que o atributo hidden sempre vença regras de display (.login/#app/.modal-fundo usam display:grid) */
[hidden] { display: none !important; }
body {
  font-family: var(--fonte);
  color: var(--texto);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(91, 140, 255, .18), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(139, 91, 255, .16), transparent 55%),
    var(--bg);
  min-height: 100vh;
}
h1, h2, h3 { font-family: var(--fonte-titulo); letter-spacing: -.02em; }
button { font-family: inherit; cursor: pointer; }
input { font-family: inherit; }

/* ===== Brand ===== */
.brand { display: flex; align-items: center; gap: 14px; }
.brand h1 { font-size: 1.7rem; }
.brand-sub { color: var(--texto-fraco); font-size: .86rem; margin-top: 2px; }
.brand-mark {
  width: 46px; height: 46px; border-radius: 13px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  display: grid; place-items: center;
  font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.5rem;
  box-shadow: 0 6px 22px -6px rgba(91, 140, 255, .7);
}
.brand-mini { gap: 10px; padding: 4px; }
.brand-mini .brand-mark { width: 36px; height: 36px; font-size: 1.2rem; border-radius: 10px; }
.brand-mini span { font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.2rem; }

/* ===== Login ===== */
.login { min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.login-card {
  width: min(420px, 100%);
  background: linear-gradient(180deg, var(--surface), var(--bg-2));
  border: 1px solid var(--linha);
  border-radius: var(--r-lg);
  padding: 38px 34px;
  box-shadow: var(--sombra);
}
.login-card .brand { margin-bottom: 28px; }
#form-login { display: flex; flex-direction: column; gap: 16px; }
label { display: flex; flex-direction: column; gap: 7px; font-size: .85rem; color: var(--texto-fraco); font-weight: 500; }
input {
  background: var(--bg); border: 1px solid var(--linha); color: var(--texto);
  padding: 12px 14px; border-radius: var(--r-sm); font-size: .98rem;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(91, 140, 255, .22); }
#btn-entrar {
  margin-top: 6px; padding: 13px; border: none; border-radius: var(--r-sm);
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; font-weight: 600; font-size: 1rem;
  transition: transform var(--dur) var(--ease), filter var(--dur) var(--ease);
}
#btn-entrar:hover { filter: brightness(1.08); transform: translateY(-1px); }
#btn-entrar:active { transform: translateY(0); }
#btn-entrar:disabled { opacity: .6; cursor: wait; }
.erro { color: var(--perigo); font-size: .86rem; text-align: center; }
.login-rodape { margin-top: 22px; text-align: center; color: var(--texto-fraco); font-size: .78rem; }

/* ===== App layout ===== */
#app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
.lateral {
  background: linear-gradient(180deg, var(--surface), var(--bg-2));
  border-right: 1px solid var(--linha);
  padding: 24px 18px; display: flex; flex-direction: column; gap: 28px;
  position: sticky; top: 0; height: 100vh;
}
#menu { display: flex; flex-direction: column; gap: 6px; flex: 1; }
#menu button {
  text-align: left; background: transparent; border: none; color: var(--texto-fraco);
  padding: 12px 14px; border-radius: var(--r-sm); font-size: .95rem; font-weight: 500;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
#menu button:hover { background: var(--surface-2); color: var(--texto); }
#menu button.ativo { background: var(--surface-2); color: var(--texto); box-shadow: inset 3px 0 0 var(--accent); }
.lateral-rodape { display: flex; flex-direction: column; gap: 12px; border-top: 1px solid var(--linha); padding-top: 18px; }
.usuario-info { display: flex; flex-direction: column; }
.usuario-info span { font-weight: 600; }
.usuario-info small { color: var(--texto-fraco); text-transform: uppercase; font-size: .68rem; letter-spacing: .08em; }
.sair { background: transparent; border: 1px solid var(--linha); color: var(--texto-fraco); padding: 9px; border-radius: var(--r-sm); transition: all var(--dur) var(--ease); }
.sair:hover { border-color: var(--perigo); color: var(--perigo); }

.conteudo { padding: 30px 38px; }
.topo { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; }
.topo h2 { font-size: 1.6rem; }
.recarregar { background: var(--surface); border: 1px solid var(--linha); color: var(--texto); padding: 9px 16px; border-radius: var(--r-sm); transition: all var(--dur) var(--ease); }
.recarregar:hover { border-color: var(--accent); }

/* ===== Cards de projeto ===== */
.grade { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 20px; }
.card {
  background: linear-gradient(180deg, var(--surface), var(--bg-2));
  border: 1px solid var(--linha); border-radius: var(--r-md); padding: 22px;
  box-shadow: var(--sombra-fraca);
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card { cursor: pointer; }
.card:hover { transform: translateY(-3px); border-color: var(--accent); }
.card-topo { display: flex; justify-content: space-between; align-items: start; gap: 10px; margin-bottom: 14px; }
.card-nome { font-family: var(--fonte-titulo); font-weight: 600; font-size: 1.12rem; word-break: break-word; }
.card-pct { font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.5rem; }
.barra { height: 9px; background: var(--bg); border-radius: 99px; overflow: hidden; margin-bottom: 6px; }
.barra > span { display: block; height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transition: width 600ms var(--ease); }
.tarefas { color: var(--texto-fraco); font-size: .82rem; margin-bottom: 16px; }
.resumo { color: var(--texto-fraco); font-size: .88rem; line-height: 1.5; margin-bottom: 16px; min-height: 1.2em; }
.metricas { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; border-top: 1px solid var(--linha); padding-top: 14px; }
.metrica small { display: block; color: var(--texto-fraco); font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 3px; }
.metrica b { font-family: var(--fonte-titulo); font-size: 1.05rem; font-weight: 600; }
.metrica.custo b { color: var(--aviso); }
.metrica.valor b { color: var(--ok); }
.card-acoes { margin-top: 14px; display: flex; gap: 8px; }
.mini { background: var(--surface-2); border: 1px solid var(--linha); color: var(--texto-fraco); padding: 6px 12px; border-radius: var(--r-sm); font-size: .82rem; transition: all var(--dur) var(--ease); }
.mini:hover { color: var(--texto); border-color: var(--accent); }
.atualizado { color: var(--texto-fraco); font-size: .72rem; margin-top: 10px; }

/* ===== Tabelas / Relatórios / Usuários ===== */
.painel-box { background: linear-gradient(180deg, var(--surface), var(--bg-2)); border: 1px solid var(--linha); border-radius: var(--r-md); padding: 22px; box-shadow: var(--sombra-fraca); }
.filtros { display: flex; gap: 14px; align-items: end; flex-wrap: wrap; margin-bottom: 22px; }
.filtros label { flex-direction: column; }
.botao { background: linear-gradient(135deg, var(--accent), var(--accent-2)); color: #fff; border: none; padding: 11px 20px; border-radius: var(--r-sm); font-weight: 600; transition: filter var(--dur) var(--ease); }
.botao:hover { filter: brightness(1.08); }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 12px 14px; border-bottom: 1px solid var(--linha); }
th { color: var(--texto-fraco); font-size: .76rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
tbody tr { transition: background var(--dur) var(--ease); }
tbody tr:hover { background: var(--surface-2); }
.total-linha td { font-family: var(--fonte-titulo); font-weight: 700; border-top: 2px solid var(--accent); color: var(--ok); }
.dinheiro { font-variant-numeric: tabular-nums; }
.tag { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.tag.admin { background: rgba(139, 91, 255, .2); color: var(--accent-2); }
.tag.usuario { background: rgba(91, 140, 255, .16); color: var(--accent); }
.acoes-tabela { display: flex; gap: 8px; }

/* ===== Modal ===== */
.modal-fundo { position: fixed; inset: 0; background: rgba(5, 8, 20, .72); backdrop-filter: blur(4px); display: grid; place-items: center; padding: 20px; z-index: 50; }
.modal { width: min(460px, 100%); background: linear-gradient(180deg, var(--surface), var(--bg-2)); border: 1px solid var(--linha); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--sombra); max-height: calc(100vh - 40px); overflow-y: auto; }
.modal h3 { margin-bottom: 18px; }
.modal form { display: flex; flex-direction: column; gap: 14px; }
.modal .linha-botoes { display: flex; gap: 10px; justify-content: flex-end; margin-top: 8px; }
.checks { display: flex; flex-direction: column; gap: 8px; max-height: 220px; overflow: auto; border: 1px solid var(--linha); border-radius: var(--r-sm); padding: 12px; }
.checks label { flex-direction: row; align-items: center; gap: 10px; color: var(--texto); cursor: pointer; }
.checks input { width: auto; }
.vazio { color: var(--texto-fraco); text-align: center; padding: 50px 20px; }

/* ===== Detalhe do projeto (tarefas) ===== */
.det-topo { display: flex; align-items: baseline; gap: 14px; margin-bottom: 10px; }
.det-topo .card-pct { font-size: 1.8rem; }
.barra.big { height: 12px; margin-bottom: 18px; }
.lista-tarefas { list-style: none; display: flex; flex-direction: column; gap: 8px; max-height: 48vh; overflow: auto; padding: 4px 4px 4px 0; margin: 0; }
.tarefa { display: grid; grid-template-columns: 22px 1fr 64px; align-items: center; gap: 10px; padding: 9px 12px; background: var(--bg); border: 1px solid var(--linha); border-radius: var(--r-sm); }
.tarefa.ok { border-color: rgba(56, 211, 159, .35); }
.tar-check { width: 20px; height: 20px; accent-color: var(--ok); cursor: pointer; }
.tar-check:disabled { opacity: .5; cursor: wait; }
.tar-marca-ro { width: 22px; height: 22px; border-radius: 6px; display: grid; place-items: center; font-weight: 700; font-size: .85rem; background: var(--surface-2); color: var(--texto-fraco); }
.tarefa.ok .tar-marca-ro { background: rgba(56, 211, 159, .18); color: var(--ok); }
.dica { color: var(--texto-fraco); font-size: .76rem; margin: 12px 0 4px; text-align: center; }

/* ===== Campo "Coloque mais ideias aqui" (detalhe do projeto) ===== */
.ideias-box { margin-top: 18px; padding-top: 16px; border-top: 1px dashed var(--linha); }
.ideias-label {
  display: block; font-family: var(--fonte-titulo); font-weight: 700;
  letter-spacing: .06em; font-size: .82rem; color: var(--accent);
  margin-bottom: 8px; text-transform: uppercase;
}
.ideias-input {
  width: 100%; resize: vertical; min-height: 64px;
  background: var(--bg); border: 1px solid var(--linha); color: var(--texto);
  padding: 12px 14px; border-radius: var(--r-sm); font-family: inherit; font-size: .98rem;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.ideias-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(91, 140, 255, .22); }
.ideias-rodape { display: flex; align-items: center; gap: 12px; margin-top: 10px; }
.botao.secundario { background: var(--surface-2); color: var(--texto); }
.ideia-status { font-size: .82rem; color: var(--texto-fraco); }
.ideia-status.ok { color: var(--ok); }
.ideia-status.erro { color: var(--perigo); }

/* bloco de custo/margem exclusivo do admin */
.metricas.admin-only { margin-top: 12px; padding-top: 14px; border-top: 1px dashed var(--linha); grid-template-columns: 1fr 1fr 1fr; }
.metrica.margem b { color: var(--ok); }
.dinheiro.neg { color: var(--perigo); }
.custo-cell { color: var(--aviso); }
.tar-desc { font-size: .9rem; line-height: 1.4; word-break: break-word; }
.tarefa.ok .tar-desc { color: var(--texto-fraco); text-decoration: line-through; }
.tar-regua { height: 7px; background: var(--surface-2); border-radius: 99px; overflow: hidden; }
.tar-regua > span { display: block; height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--accent), var(--ok)); transition: width 400ms var(--ease); }
select { background: var(--bg); border: 1px solid var(--linha); color: var(--texto); padding: 12px 14px; border-radius: var(--r-sm); font-size: .96rem; }

/* ===== Responsivo ===== */
@media (max-width: 820px) {
  #app { grid-template-columns: 1fr; }
  .lateral { position: static; height: auto; flex-direction: row; flex-wrap: wrap; align-items: center; }
  #menu { flex-direction: row; flex-wrap: wrap; }
  .conteudo { padding: 22px 18px; }
}
