:root{
  --roxo:#211843;
  --roxo-2:#2d1f5e;
  --cyan:#75EFFF;
  --cyan-d:#3fd6ea;
  --txt:#ede9ff;
  --txt-sub:#b8b0d8;
  --erro:#ff6b7d;
  --card:#1a1238;
  --borda:rgba(117,239,255,.18);
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--txt);
  -webkit-font-smoothing:antialiased;
}

/* ---------- Telas de autenticação ---------- */
.tela-auth{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:
    radial-gradient(900px 500px at 50% -10%, rgba(117,239,255,.12), transparent 60%),
    linear-gradient(160deg, var(--roxo) 0%, #150d2e 100%);
}
.card{
  width:100%;max-width:400px;
  background:var(--card);
  border:1px solid var(--borda);
  border-radius:18px;
  padding:36px 30px;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
}
.logo{
  font-weight:800;font-size:15px;letter-spacing:.3px;
  color:var(--txt-sub);margin-bottom:22px;
}
.logo span{color:var(--cyan)}
.card h1{font-size:24px;font-weight:800;margin-bottom:6px}
.sub{color:var(--txt-sub);font-size:14px;margin-bottom:22px;line-height:1.5}

label{display:block;font-size:13px;color:var(--txt-sub);margin-bottom:14px}
input{
  width:100%;margin-top:6px;
  background:#120c29;color:var(--txt);
  border:1px solid var(--borda);border-radius:10px;
  padding:12px 14px;font-size:15px;outline:none;
  transition:border-color .15s,box-shadow .15s;
}
input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(117,239,255,.15)}

.btn{
  display:block;width:100%;text-align:center;
  margin-top:6px;
  background:linear-gradient(90deg,var(--cyan),var(--cyan-d));
  color:#0c0820;font-weight:800;font-size:15px;
  border:none;border-radius:10px;padding:13px;
  cursor:pointer;text-decoration:none;
  transition:transform .08s,filter .15s;
}
.btn:hover{filter:brightness(1.05)}
.btn:active{transform:translateY(1px)}

.alerta{
  background:rgba(255,107,125,.12);
  border:1px solid rgba(255,107,125,.35);
  color:var(--erro);
  border-radius:10px;padding:11px 14px;font-size:13.5px;
  margin-bottom:18px;line-height:1.45;
}
.rodape{margin-top:20px;text-align:center;font-size:13.5px;color:var(--txt-sub)}
.rodape a,.sub a{color:var(--cyan);text-decoration:none;font-weight:600}
.rodape a:hover,.sub a:hover{text-decoration:underline}

/* ---------- Área logada ---------- */
.tela-app{
  min-height:100vh;
  background:linear-gradient(160deg,var(--roxo) 0%, #140c2c 100%);
}
.topo{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;border-bottom:1px solid var(--borda);
}
.usuario{display:flex;align-items:center;gap:16px;font-size:13.5px;color:var(--txt-sub)}
.sair{color:var(--cyan);text-decoration:none;font-weight:600}
.sair:hover{text-decoration:underline}
.conteudo{max-width:980px;margin:0 auto;padding:40px 28px}
.conteudo h1{font-size:28px;margin-bottom:10px}
.conteudo p{color:var(--txt-sub);line-height:1.6;max-width:640px}
.grid-placeholder{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:14px;margin-top:30px;
}
.bloco{
  background:var(--card);border:1px solid var(--borda);
  border-radius:14px;padding:26px 18px;font-weight:700;
  color:var(--txt-sub);text-align:center;
}
.bloco:hover{border-color:var(--cyan);color:var(--txt)}

/* ---------- Tela de nichos ---------- */
.conteudo-largo{max-width:1180px}
.sub-pag{color:var(--txt-sub);margin-bottom:22px;max-width:760px;line-height:1.55}

.filtros{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}
.filtros input[type=search]{flex:1;min-width:220px;margin:0}
.filtros select{
  background:#120c29;color:var(--txt);border:1px solid var(--borda);
  border-radius:10px;padding:11px 12px;font-size:14px;outline:none;cursor:pointer;
}
.contador{color:var(--txt-sub);font-size:13px;margin-left:auto}

.tabela-wrap{
  background:var(--card);border:1px solid var(--borda);
  border-radius:14px;overflow:hidden;
}
.tabela-nichos{width:100%;border-collapse:collapse;font-size:14px}
.tabela-nichos thead th{
  text-align:left;padding:13px 14px;color:var(--txt-sub);
  font-size:12px;text-transform:uppercase;letter-spacing:.4px;
  border-bottom:1px solid var(--borda);background:#160f33;
}
.tabela-nichos tbody tr{border-bottom:1px solid rgba(117,239,255,.07);cursor:pointer}
.tabela-nichos tbody tr:hover{background:rgba(117,239,255,.05)}
.tabela-nichos td{padding:12px 14px;vertical-align:middle}
.tabela-nichos .rk{color:var(--txt-sub);width:38px}
.tabela-nichos .nm{font-weight:700;color:var(--txt);white-space:nowrap}
.tabela-nichos .dor{color:var(--txt-sub);max-width:340px}
.tabela-nichos .ver{
  background:transparent;border:1px solid var(--borda);color:var(--cyan);
  border-radius:8px;padding:6px 10px;font-size:12.5px;cursor:pointer;font-weight:600;
}
.tabela-nichos .ver:hover{border-color:var(--cyan)}

.nota{font-weight:800;padding:3px 9px;border-radius:7px;font-size:13px}
.nota.verde{background:rgba(80,220,160,.15);color:#6ee7b0}
.nota.amar{background:rgba(255,210,100,.13);color:#ffd166}
.nota.cinza{background:rgba(180,170,210,.12);color:var(--txt-sub)}
.pill{font-weight:700;padding:3px 10px;border-radius:20px;font-size:12px}
.pill.verde{background:rgba(80,220,160,.15);color:#6ee7b0}
.pill.amar{background:rgba(255,210,100,.13);color:#ffd166}
.pill.cinza{background:rgba(180,170,210,.12);color:var(--txt-sub)}
.vazio{padding:30px;text-align:center;color:var(--txt-sub)}

/* ---------- Drawer ---------- */
.overlay{position:fixed;inset:0;background:rgba(6,3,18,.6);z-index:40}
.drawer{
  position:fixed;top:0;right:0;height:100vh;width:460px;max-width:92vw;z-index:50;
  background:#160f33;border-left:1px solid var(--borda);
  box-shadow:-20px 0 50px rgba(0,0,0,.5);
  overflow-y:auto;padding:26px 24px 40px;
}
.drawer .fechar{
  position:absolute;top:14px;right:16px;background:none;border:none;
  color:var(--txt-sub);font-size:30px;line-height:1;cursor:pointer;
}
.drawer .fechar:hover{color:var(--txt)}
.d-head{margin-bottom:18px;padding-right:30px}
.d-rank{color:var(--cyan);font-weight:800;font-size:13px}
.d-head h2{font-size:22px;margin:4px 0 10px}
.d-badges{display:flex;gap:8px}
.d-campo{margin-bottom:14px}
.d-label{display:block;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--cyan);font-weight:700;margin-bottom:4px}
.d-valor{color:var(--txt);font-size:14px;line-height:1.5}
.d-sep{margin:22px 0 12px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-sub);border-top:1px solid var(--borda);padding-top:14px;font-weight:700}
.d-msg{background:#120c29;border:1px solid var(--borda);border-radius:11px;padding:12px 14px;margin-bottom:12px}
.d-msg-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.d-msg-txt{color:var(--txt);font-size:13.5px;line-height:1.55;white-space:pre-wrap}
.copiar{background:var(--cyan);color:#0c0820;border:none;border-radius:7px;padding:5px 11px;font-size:12px;font-weight:800;cursor:pointer}
.copiar:hover{filter:brightness(1.05)}

@media(max-width:680px){
  .tabela-nichos .dor{display:none}
  .topo .usuario span{display:none}
}

.bloco{display:block;text-decoration:none}
.bloco small{display:block;font-size:11px;color:var(--txt-sub);font-weight:500;margin-top:6px;opacity:.7}
a.bloco.ativo{color:var(--txt);border-color:var(--cyan)}
a.bloco.ativo:hover{background:rgba(117,239,255,.07)}
