/* assets/app.css — Primus (Revisado/Auditado)
   ===========================================
   ✅ Mantém compatibilidade com seus arquivos atuais (dashboard/leads/kanban/email/whatsapp)
   ✅ Fundo mais “clean” e com melhor legibilidade (sem “preto chapado”)
   ✅ Sidebar + itens ativos padronizados
   ✅ Badges no menu (sb-badge) pronto
   ✅ Melhorias: foco acessível, hover suave, scrollbars, tabelas, campos e botões consistentes
*/

/* =========================
   THEME TOKENS
========================= */
:root{
  --primus-blue:#2d6cff;
  --primus-gold:#c5a059;

  /* Base (mais claro/clean que o preto puro) */
  --bg-0:#0b1020;
  --bg-1:#0d1426;
  --bg-2:#0f1830;

  /* Superfícies */
  --panel:#0f172a;   /* fundo dos painéis */
  --card:#111c33;    /* cards */
  --card2:#0e162b;   /* variação de card */
  --glass:rgba(255,255,255,.04);

  /* Texto */
  --text:#eaf0ff;
  --muted:#9bb0d6;

  /* Bordas/sombras */
  --line:rgba(255,255,255,.08);
  --line2:rgba(255,255,255,.12);
  --shadow:0 14px 40px rgba(0,0,0,.35);

  /* Realces */
  --glow:rgba(45,108,255,.30);
  --glow2:rgba(197,160,89,.18);

  /* Estados */
  --ok:rgba(0,255,170,.85);
  --ok-bg:rgba(0,255,170,.08);
  --ok-br:rgba(0,255,170,.22);

  --danger:#ff5a67;
  --danger-bg:rgba(255,90,103,.10);
  --danger-br:rgba(255,90,103,.22);

  --warn:#ffd36a;
  --warn-bg:rgba(255,211,106,.10);
  --warn-br:rgba(255,211,106,.22);

  --radius:22px;
  --radius-md:16px;
  --radius-sm:14px;

  --focus:0 0 0 4px rgba(45,108,255,.18);
}

/* =========================
   RESET / BASE
========================= */
*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--text);

  /* Fundo “clean” (menos escuro e com profundidade) */
  background:
    radial-gradient(900px 520px at 62% 8%, rgba(45,108,255,.14), transparent 60%),
    radial-gradient(700px 520px at 12% 38%, rgba(197,160,89,.10), transparent 60%),
    radial-gradient(900px 700px at 50% 110%, rgba(0,0,0,.35), transparent 60%),
    linear-gradient(180deg, var(--bg-0), var(--bg-1) 45%, var(--bg-2));
}

/* Links */
a{color:inherit}
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible{
  outline:none;
  box-shadow:var(--focus);
  border-color:rgba(45,108,255,.35) !important;
}

/* Scrollbar (WebKit) */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:999px}
*::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:999px}
*::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.20)}

/* =========================
   DASH LAYOUT
========================= */
.dash-body{display:flex;min-height:100vh}

/* =========================
   SIDEBAR
========================= */
.sidebar{
  width:84px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-right:1px solid var(--line);
  padding:18px 10px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
  backdrop-filter: blur(10px);
}

.sb-top{width:100%;display:flex;justify-content:center}
.sb-logo{display:flex;align-items:center;gap:10px}

.sb-logo .dot{
  width:12px;height:12px;border-radius:4px;
  background:linear-gradient(180deg, #3b7bff, #1b4fd6);
  box-shadow:0 0 26px rgba(45,108,255,.35);
}

.sb-brand{
  font-weight:900;
  letter-spacing:.4px;
  font-size:12px;
  color:rgba(255,255,255,.78)
}

.sb-nav{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:10px;
  flex:1
}

.sb-item{
  width:46px;height:46px;border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.74);
  cursor:pointer;
  text-decoration:none;
  position:relative;
  transition: transform .12s ease, border-color .12s ease, background .12s ease, color .12s ease;
}

.sb-item:hover{
  border-color:rgba(45,108,255,.38);
  transform: translateY(-1px);
}

.sb-item.active{
  background:rgba(45,108,255,.14);
  border-color:rgba(45,108,255,.42);
  color:#d7e6ff;
  box-shadow: 0 10px 26px rgba(45,108,255,.10);
}

.sb-bottom{margin-bottom:6px}

/* Badge no menu */
.sb-badge{
  position:absolute;
  top:10px;
  right:10px;
  min-width:18px;
  height:18px;
  padding:0 6px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:950;
  background:rgba(220,38,38,.12);
  border:1px solid rgba(220,38,38,.22);
  color:#ffd2d6;
}

/* =========================
   MAIN
========================= */
.dash-main{flex:1; padding:20px 24px}

/* =========================
   TOPBAR (Dashboard padrão)
========================= */
.dash-topbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}

.dash-title{font-size:26px;font-weight:950;letter-spacing:-.2px}
.dash-sub{color:rgba(255,255,255,.55);font-size:13px;margin-top:4px}

.dash-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

.pill-btn{
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.90);
  padding:10px 14px;
  border-radius:999px;
  cursor:pointer;
  display:flex;align-items:center;gap:10px;
  transition: border-color .12s ease, transform .12s ease, background .12s ease;
}
.pill-btn:hover{border-color:rgba(45,108,255,.35);transform:translateY(-1px)}

.icon-btn{
  width:44px;height:44px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.84);
  cursor:pointer;
  transition: border-color .12s ease, transform .12s ease, background .12s ease;
}
.icon-btn:hover{border-color:rgba(45,108,255,.35);transform:translateY(-1px)}

.avatar{
  width:42px;height:42px;border-radius:999px;
  background:linear-gradient(180deg, #3b7bff, #1b4fd6);
  display:flex;align-items:center;justify-content:center;
  font-weight:950;
  box-shadow:0 10px 26px rgba(45,108,255,.18);
}

.search{
  width:320px;
  display:flex;align-items:center;gap:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  border-radius:999px;
  padding:10px 14px;
}
.search input{
  width:100%;
  border:0;outline:none;
  background:transparent;
  color:rgba(255,255,255,.90);
}
.search input::placeholder{color:rgba(255,255,255,.45)}

/* =========================
   FILTERS (genérico)
========================= */
.filters{
  margin-top:16px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:flex-end;
}

.filter{min-width:170px}
.filter.grow{flex:1;min-width:240px}

.label{
  font-size:12px;
  color:rgba(255,255,255,.55);
  margin-bottom:6px;
  font-weight:800;
}

.select, .input{
  width:100%;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.90);
  border-radius:14px;
  padding:10px 12px;
  outline:none;
}
.select:focus, .input:focus{border-color:rgba(45,108,255,.35)}
.input::placeholder{color:rgba(255,255,255,.45)}

/* =========================
   GRID / CARDS
========================= */
.dash-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1.1fr 2.2fr;
  grid-template-rows: auto auto;
  gap:16px;
}

.card{
  border:1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}

.kpi-card{grid-column:1; grid-row:1}
.hero{grid-column:2; grid-row:1}
.top-camps{grid-column:1; grid-row:2}
.all-camps{grid-column:2; grid-row:2}

/* =========================
   KPI CARD
========================= */
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card-k{color:rgba(255,255,255,.60);font-size:13px;font-weight:700}
.card-v{font-size:34px;font-weight:950;letter-spacing:-.5px;margin-top:4px}

.kpi-icon{
  width:42px;height:42px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:var(--ok-bg);
  border:1px solid var(--ok-br);
  color:var(--ok);
}

.mini-list{margin-top:14px;display:flex;flex-direction:column;gap:10px}

.mini{
  border:1px solid var(--line);
  background:rgba(0,0,0,.10);
  border-radius:16px;
  padding:12px 14px;
  display:flex;align-items:center;justify-content:space-between;
}

.mini-l{
  display:flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.62);
  font-size:13px;
  font-weight:800;
}

.mini-v{font-weight:950}
.mini-v.blue{color:#8ab6ff}

/* =========================
   HERO
========================= */
.hero{
  background:
    radial-gradient(820px 440px at 65% 20%, rgba(45,108,255,.22), transparent 60%),
    radial-gradient(700px 520px at 25% 55%, rgba(197,160,89,.12), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  position:relative;
  overflow:hidden;
}

.hero-pill{
  position:absolute; top:16px; left:18px;
  border:1px solid rgba(45,108,255,.35);
  background:rgba(45,108,255,.12);
  color:#d7e6ff;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  display:flex;align-items:center;gap:10px;
  font-weight:900;
}

.hero-title{
  text-align:center;
  font-size:30px;
  font-weight:950;
  margin-top:40px;
}

.hero-sub{
  text-align:center;
  margin-top:10px;
  color:rgba(255,255,255,.62);
  font-size:14px;
  font-weight:800;
}

.hero-chip{
  padding:4px 10px;
  border-radius:10px;
  background:rgba(45,108,255,.16);
  border:1px solid rgba(45,108,255,.34);
  color:#d7e6ff;
  font-weight:950;
}

.hero-actions{display:flex;justify-content:center;margin-top:18px}

.hero-btn{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.92);
  color:#0b1020;
  font-weight:950;
  padding:12px 18px;
  border-radius:999px;
  cursor:pointer;
  display:flex;align-items:center;gap:10px;
  transition: transform .12s ease, filter .12s ease;
}
.hero-btn:hover{transform:translateY(-1px);filter:brightness(.98)}

/* =========================
   TOP CAMPAIGNS
========================= */
.card-title-row{display:flex;align-items:center;justify-content:space-between}
.card-title{font-weight:950}

.ghost{
  width:36px;height:36px;border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.80);
  cursor:pointer;
  transition: border-color .12s ease, transform .12s ease, background .12s ease;
}
.ghost:hover{border-color:rgba(45,108,255,.35);transform:translateY(-1px)}

.top-list{margin-top:14px;display:flex;flex-direction:column;gap:12px}

.top-item{
  border:1px solid var(--line);
  background:rgba(0,0,0,.10);
  border-radius:18px;
  padding:14px;
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;
}

.rank{
  width:38px;height:38px;border-radius:12px;
  background:rgba(45,108,255,.18);
  border:1px solid rgba(45,108,255,.32);
  display:flex;align-items:center;justify-content:center;
  font-weight:950;
}

.top-name{
  font-weight:950;
  font-size:13px;
  max-width:220px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.top-sub{color:rgba(255,255,255,.58);font-size:12px;margin-top:4px;font-weight:800}

.cpl-badge{
  border:1px solid var(--ok-br);
  background:var(--ok-bg);
  color:var(--ok);
  padding:8px 10px;
  border-radius:14px;
  font-weight:950;
  font-size:12px;
  text-align:right;
  min-width:110px;
}
.cpl-badge span{
  display:block;
  color:rgba(255,255,255,.55);
  font-weight:800;
  font-size:10px;
  margin-top:2px
}

/* =========================
   TABLES
========================= */
.pill{
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  color:rgba(255,255,255,.68);
  font-weight:900;
}

.table-wrap{
  margin-top:10px;
  max-height:360px;
  overflow:auto;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.08);
}

.dash-table{
  width:100%;
  border-collapse:collapse;
}
.dash-table th,.dash-table td{
  padding:12px 10px;
  border-bottom:1px solid var(--line);
  font-size:13px
}
.dash-table th{
  color:rgba(255,255,255,.62);
  font-weight:900;
  position:sticky;
  top:0;
  background:rgba(14,22,43,.88);
  backdrop-filter: blur(10px);
}
.dash-table tr:hover td{background:rgba(255,255,255,.03)}
.right{text-align:right}

/* Status */
.status-pill{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:950;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.72);
}
.status-pill.active{
  border-color:var(--ok-br);
  background:var(--ok-bg);
  color:var(--ok);
}
.status-pill.paused{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.02);
  color:rgba(255,255,255,.58);
}

/* =========================
   FORMS / BUTTONS (genérico)
========================= */
button{font-family:inherit}
button:disabled{opacity:.6;cursor:not-allowed}

.btn, .btn-primary, .btn-mini{
  transition: transform .12s ease, border-color .12s ease, background .12s ease, filter .12s ease;
}
.btn:hover, .btn-primary:hover, .btn-mini:hover{transform:translateY(-1px)}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1100px){
  .dash-grid{grid-template-columns:1fr;}
  .kpi-card,.hero,.top-camps,.all-camps{grid-column:1}
  .search{width:220px}
}

@media (max-width: 720px){
  .sidebar{display:none}
  .dash-main{padding:16px}
  .dash-topbar{flex-direction:column;align-items:stretch}
  .dash-actions{flex-wrap:wrap}
  .search{width:100%}
  .filters{gap:10px}
  .filter{min-width:150px}
  .filter.grow{min-width:180px}
}