:root{
  --bg:#2b2b2b;
  --card:#5c5c5c;
  --text:#f1f1f1;
  --muted:#cfcfcf;

  --primary:#7c3aed;
  --secondary:#6b7280;
  --danger:#ef4444;
  --input:#ededed;
  --input-border:#bdbdbd;

  --table-border:#8a8a8a;
  --radius:14px;
}

/* Reset */
*{box-sizing:border-box;margin:0;padding:0}

/* Tipografia (SF Pro Display) */
body{
  font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Ubuntu,Cantarell,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.4;
  font-weight:400;
}

/* ===== TOPO ===== */
.topbar{ padding:32px 16px 12px; text-align:center; }
.hero h1{
  margin:0 0 10px 0; font-size:44px; font-weight:800; letter-spacing:.6px;
  background:linear-gradient(90deg,#ffffff,#d9d9ff 70%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero p{ margin:0; color:var(--muted); font-size:18px; letter-spacing:.2px; }

/* ===== TOOLBAR ===== */
.toolbar{
  margin:24px auto 0; max-width:1000px; display:flex; flex-wrap:wrap;
  justify-content:center; align-items:center; gap:12px;
}

/* Busca */
.search-wrap{ position:relative; display:flex; align-items:center; }
.search-wrap svg{
  width:20px;height:20px; position:absolute; left:14px; top:50%; transform:translateY(-50%);
  pointer-events:none;
}
.search-wrap input{
  width:320px; height:44px; line-height:44px; padding:0 16px 0 42px;
  border:1px solid var(--input-border); border-radius:24px;
  background:#ededed; color:#333; font-weight:400;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 2px 8px rgba(0,0,0,.15);
  outline:none;
}
.search-wrap input:focus,
.search-wrap input:focus-visible{
  outline:none; box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 2px 8px rgba(0,0,0,.15);
  border-color:var(--input-border);
}
.search-wrap input::placeholder{ color:#7a7a7a; }

/* Select (pill) */
.pill{
  height:44px; line-height:44px; border-radius:24px; min-width:170px; padding:0 20px;
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background:#ededed; color:#333; border:1px solid var(--input-border); font-weight:500;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 2px 8px rgba(0,0,0,.15);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat; background-position:right 12px center; background-size:16px 16px;
  padding-right:44px;
  outline:none;
}
.pill:focus,
.pill:focus-visible{ outline:none; box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 2px 8px rgba(0,0,0,.15); }

/* Botões */
.btn{
  height:44px; padding:0 20px; border-radius:24px; border:0; font-weight:500;
  cursor:pointer; transition:.2s; display:inline-flex; align-items:center; justify-content:center; gap:8px; line-height:1;
  outline:none;
}
.btn img{ width:18px;height:18px; display:block; }
.btn.primary{ background:linear-gradient(90deg,#8b5cf6,#7c3aed); color:#fff; }
.btn.secondary{ background:#2f2f2f; border:1px solid #5b5b5b; color:#e5e7eb; }
.btn.ghost{ background:transparent; color:#e5e7eb; border:1px solid #9ca3af; }
.btn:hover{ opacity:.9; }
.btn:focus,
.btn:focus-visible{ outline:none; }

/* ===== TABELA ===== */
.container{ max-width:1000px; margin:24px auto 0; padding:0 16px; }

.table{
  width:100%; border-collapse:separate; border-spacing:0;
  border-radius:18px; overflow:hidden;
  background:#3a3a3a80; backdrop-filter:saturate(120%) blur(4px);
}
.table thead th{
  background:#505050; color:#fff; text-align:left; padding:16px; font-weight:700;
  border-bottom:1px solid #7a7a7a; position:sticky; top:0; z-index:1; letter-spacing:.2px;
}
.table tbody td{
  padding:16px; border-bottom:1px solid #ffffff12; color:#f5f5f5; vertical-align:middle;
}
/* sem movimento, só muda o fundo */
.table tbody tr{
  transition:background .18s ease;
}
.table tbody tr:hover{
  background:#ffffff12;
}
.table tbody tr:last-child td{ border-bottom:0; }
.col-acoes{ text-align:center; width:140px; }
.empty{ text-align:center; color:var(--muted); padding:18px; }
.summary{ text-align:center; color:#a3a3a3; margin:14px 0 0; }

/* Avatar + nome */
.name-cell{ display:flex; align-items:center; gap:8px; }
.avatar{
  width:28px; height:28px; border-radius:50%; background:#8b5cf6; color:#fff;
  display:inline-grid; place-items:center; font-weight:700; font-size:12px;
}

/* Ações */
.action-wrap{ display:flex; justify-content:center; align-items:center; gap:10px; }
.icon-btn{
  width:42px; height:42px; border-radius:50%; display:grid; place-items:center; border:0; cursor:pointer;
  background:#7c3aed; transition:transform .2s ease; outline:none;
}
.icon-btn:hover{ transform:scale(1.08); }
.icon-btn img{ width:20px;height:20px; display:block; }
.icon-btn.danger{ background:#e5484d; }
.icon-btn:focus,
.icon-btn:focus-visible{ outline:none; }

/* ===== RODAPÉ ===== */
.footer{ text-align:center; color:var(--muted); padding:36px 16px 28px; }
.footer a{ color:#a78bfa; text-decoration:none; font-weight:700; }
.footer a:hover{ text-decoration:underline; }

/* ===== MODAL ===== */
.modal{ position:fixed; inset:0; display:none; }
.modal.show{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.55); backdrop-filter:blur(2px); }
.modal-content{
  position:relative; width:min(640px,92vw); margin:8vh auto; background:#3a3a3a; color:#fff;
  border:1px solid #5b5b5b; border-radius:18px;
}
.modal-header{ display:flex; justify-content:space-between; align-items:center; padding:18px 20px 8px; }
.modal-header h2{ margin:0; font-size:24px; font-weight:700; }
.modal-header .icon-btn{ width:36px; height:36px; background:transparent; border:1px solid #6b6b6b; color:#e5e7eb; outline:none; }

.modal-body{ padding:0 20px 20px; display:grid; gap:14px; }
.field{ display:flex; flex-direction:column; gap:6px; }
.field>span{ font-weight:500; }
.field input{
  padding:12px 14px; border-radius:10px; border:1px solid #7a7a7a; background:#2f2f2f; color:#f3f3f3; outline:none;
}
.field input::placeholder{ color:#9e9e9e; }
.field input:focus,
.field input:focus-visible{
  outline:none; border-color:#7a7a7a; box-shadow:none;
}

.modal-actions{ margin-top:8px; display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap; }
.modal-actions .btn{ padding:12px 18px; }

/* ===== TOAST ===== */
.toast{
  position:fixed; left:50%; bottom:28px; transform:translateX(-50%);
  background:#2f2f2f; color:#fff; border:1px solid #5b5b5b;
  padding:10px 14px; border-radius:10px; opacity:0; pointer-events:none;
  transition:opacity .2s, transform .2s; z-index:50;
}
.toast.show{ opacity:1; transform:translate(-50%,-4px); }

/* ===== FAB (mobile) ===== */
.fab{
  position:fixed; right:22px; bottom:22px; z-index:40;
  width:56px; height:56px; border-radius:50%; border:0;
  display:none; place-items:center; font-size:28px; font-weight:700;
  background:linear-gradient(90deg,#8b5cf6,#7c3aed); color:#fff; cursor:pointer;
  box-shadow:0 8px 24px rgba(0,0,0,.35); outline:none;
}
.fab:focus,
.fab:focus-visible{ outline:none; }
@media (max-width:720px){ .fab{ display:grid; } }

/* ===== Cards no mobile ===== */
@media (max-width:720px){
  table.table, .table thead { display:none; }
  #tbody{ display:grid; gap:10px; }
  #tbody tr{ display:grid; padding:14px; border:1px solid #6b6b6b; border-radius:14px; background:#3a3a3a; }
  #tbody td{ border:0; padding:6px 0; }
  #tbody td:nth-child(1)::before{ content:"Nome • "; color:#bbb; }
  #tbody td:nth-child(2)::before{ content:"E-mail • "; color:#bbb; }
  #tbody td:nth-child(3)::before{ content:"Telefone • "; color:#bbb; }
  .col-acoes{ text-align:left; }
}

/* Sem outline global */
@media (prefers-reduced-motion:reduce){ *{ transition:none !important; animation:none !important; } }
