/* ============ SUPER CRM - Tema G8 (roxo & branco) ============ */
:root{
  --violet-900:#3b0a6b;
  --violet-800:#4c1d95;
  --violet-700:#5b21b6;
  --violet-600:#6d28d9;
  --violet-500:#7c3aed;
  --violet-400:#8b5cf6;
  --violet-300:#c4b5fd;
  --violet-200:#ddd6fe;
  --violet-100:#ede9fe;
  --violet-50:#f5f3ff;
  --ink:#191427;
  --muted:#6b6385;
  --line:#ece8f6;
  --bg:#f4f2fb;
  --white:#ffffff;
  --green:#16a34a; --green-bg:#dcfce7;
  --red:#dc2626;  --red-bg:#fee2e2;
  --amber:#d97706;--amber-bg:#fef3c7;
  --grad:linear-gradient(135deg,#8b5cf6,#6d28d9);
  --grad-soft:linear-gradient(135deg,#a78bfa,#7c3aed);
  --radius:18px;
  --shadow:0 18px 40px -18px rgba(76,29,149,.30);
  --shadow-sm:0 4px 16px -6px rgba(76,29,149,.16);
  --shadow-card:0 1px 2px rgba(24,16,48,.04), 0 8px 24px -16px rgba(76,29,149,.30);
  font-synthesis:none;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--ink); font-size:14.5px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--violet-600);text-decoration:none}
.ic{vertical-align:-3px}

/* ---------- Layout app ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:256px;flex:0 0 256px;
  background:
    radial-gradient(420px 220px at 30% -8%, rgba(167,139,250,.32), transparent 70%),
    linear-gradient(185deg,#4c1d95 0%,#3b0f74 55%,#2c0a57 100%);
  color:#e9e3ff;padding:20px 16px;position:sticky;top:0;height:100vh;
  box-shadow:inset -1px 0 0 rgba(255,255,255,.06);
}
.brand{display:flex;align-items:center;gap:13px;padding:8px 8px 22px}
.brand-logo{filter:drop-shadow(0 4px 10px rgba(20,10,45,.3));flex:0 0 auto}
.brand-txt b{font-size:16px;color:#fff;letter-spacing:.1px;display:block;line-height:1.15;font-weight:800}
.brand-txt span{font-size:11px;color:#c4b5fd}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav a{position:relative;display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;color:#cdbef7;font-weight:500;transition:.18s ease}
.nav a .ic{opacity:.85;transition:.18s}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav a:hover .ic{opacity:1}
.nav a.active{background:linear-gradient(90deg,rgba(255,255,255,.18),rgba(255,255,255,.06));color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.10)}
.nav a.active::before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:#fff;box-shadow:0 0 12px rgba(255,255,255,.6)}
.nav a.active .ic{opacity:1}
.nav .sep{height:1px;background:rgba(255,255,255,.10);margin:12px 6px}
.side-foot{position:absolute;bottom:16px;left:18px;right:18px;font-size:11px;color:#a995e6;letter-spacing:.2px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:66px;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;padding:0 30px;position:sticky;top:0;z-index:5}
.topbar h1{font-size:18px;margin:0;font-weight:800;letter-spacing:-.2px}
.topbar .who{display:flex;align-items:center;gap:11px;color:var(--muted);font-size:13px}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--grad-soft);color:#fff;
  display:grid;place-items:center;font-weight:800;box-shadow:0 6px 16px -6px rgba(124,58,237,.6)}
.content{padding:28px 30px;max-width:1200px;width:100%}

/* ---------- Componentes ---------- */
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card)}
.card.pad{padding:24px}
.card h2{font-size:15px;margin:0 0 14px;font-weight:800;letter-spacing:-.2px}
.grid{display:grid;gap:18px}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid.c3,.grid.c4,.grid.c2{grid-template-columns:1fr}}

.stat{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;box-shadow:var(--shadow-card);overflow:hidden;transition:transform .18s ease, box-shadow .18s ease}
.stat::after{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--grad);opacity:.9}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.stat .lbl{color:var(--muted);font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:8px}
.stat .val{font-size:32px;font-weight:900;margin-top:8px;letter-spacing:-1px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .ico{width:42px;height:42px;border-radius:13px;background:var(--violet-50);color:var(--violet-600);
  display:grid;place-items:center;float:right;box-shadow:inset 0 0 0 1px var(--violet-100)}

.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 17px;border-radius:12px;border:1px solid transparent;
  font-weight:700;font-size:13.5px;cursor:pointer;transition:.18s ease;background:var(--grad);color:#fff;text-decoration:none;
  box-shadow:0 8px 18px -8px rgba(109,40,217,.65)}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 12px 22px -8px rgba(109,40,217,.7)}
.btn:active{transform:translateY(0)}
.btn.sec{background:var(--violet-50);color:var(--violet-700);border-color:var(--violet-100);box-shadow:none}
.btn.sec:hover{background:var(--violet-100);filter:none}
.btn.ghost{background:transparent;color:var(--muted);border-color:var(--line);box-shadow:none}
.btn.ghost:hover{color:var(--violet-700);border-color:var(--violet-200);background:var(--violet-50);filter:none}
.btn.danger{background:var(--red-bg);color:var(--red);box-shadow:none}
.btn.danger:hover{background:#fecaca;filter:none}
.btn.sm{padding:7px 11px;font-size:12.5px;border-radius:9px}
.btn.block{width:100%;justify-content:center}

.input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:11px;font:inherit;
  background:#fff;color:var(--ink);transition:.15s;outline:none}
.input:focus,select:focus,textarea:focus{border-color:var(--violet-400);box-shadow:0 0 0 3px var(--violet-100)}
label{font-size:12.5px;font-weight:600;color:var(--muted);display:block;margin:0 0 6px}
.field{margin-bottom:16px}
textarea{resize:vertical;min-height:90px}

table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);
  padding:11px 14px;border-bottom:1px solid var(--line);font-weight:700}
td{padding:12px 14px;border-bottom:1px solid var(--line);font-size:13.5px}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--violet-50)}

.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:700}
.badge.green{background:var(--green-bg);color:var(--green)}
.badge.red{background:var(--red-bg);color:var(--red)}
.badge.amber{background:var(--amber-bg);color:var(--amber)}
.badge.violet{background:var(--violet-100);color:var(--violet-700)}
.dot{width:8px;height:8px;border-radius:50%}
.dot.green{background:var(--green)}.dot.red{background:var(--red)}.dot.amber{background:var(--amber)}

.flash{padding:13px 16px;border-radius:12px;margin-bottom:18px;font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:10px}
.flash.ok{background:var(--green-bg);color:#166534}
.flash.err{background:var(--red-bg);color:#991b1b}
.flash.info{background:var(--violet-100);color:var(--violet-800)}

.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}
.page-head .ttl{font-size:22px;font-weight:900;margin:0;letter-spacing:-.5px}
.page-head .sub{color:var(--muted);font-size:13px;margin-top:2px}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;align-items:center}
.row.wrap{flex-wrap:wrap}
.spacer{flex:1}
.empty{text-align:center;padding:50px 20px;color:var(--muted)}
.empty .ic{color:var(--violet-300)}

/* chips de tipo de mídia */
.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:9px;border:1px solid var(--line);
  font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;background:#fff}
.chip.on{background:var(--violet-600);color:#fff;border-color:var(--violet-600)}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;position:relative;overflow:hidden;
  background:radial-gradient(1100px 520px at 50% -12%,#7c3aed 0%,#4c1d95 45%,#26073f 100%)}
.login-wrap::before,.login-wrap::after{content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.5}
.login-wrap::before{width:360px;height:360px;background:#a78bfa;top:-90px;left:-60px}
.login-wrap::after{width:320px;height:320px;background:#6d28d9;bottom:-110px;right:-40px}
.login-card{position:relative;z-index:1;width:388px;max-width:92vw;background:rgba(255,255,255,.98);
  border:1px solid rgba(255,255,255,.6);border-radius:24px;padding:36px 32px;
  box-shadow:0 40px 80px -24px rgba(20,4,40,.6)}
.login-logo{display:flex;justify-content:center;margin-bottom:14px}
.login-logo .brand-logo{filter:drop-shadow(0 10px 22px rgba(76,29,149,.3))}
.login-card h1{text-align:center;font-size:21px;margin:0 0 2px;font-weight:800;letter-spacing:-.3px}
.login-card .sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:24px}
.qr-box{display:grid;place-items:center;padding:14px;background:var(--violet-50);border-radius:14px;border:1px dashed var(--violet-200)}
.qr-box img{width:248px;height:248px;border-radius:8px;background:#fff}
.mono{font-family:ui-monospace,Consolas,monospace}
