/* ============================================================
   TOVIX — Design System (refresh)
   Direção: minimalismo refinado "padrão Apple"
   Marca: navy profundo + azul elétrico (gradiente do logo)
   Compatível com os mesmos seletores do sistema anterior.
   ============================================================ */

:root{
  /* Superfícies — cinza frio, limpo, ar de iOS/macOS */
  --bg:            #EEF1F7;
  --bg-2:          #F4F6FB;
  --surface:       #FFFFFF;
  --surface-2:     #F6F8FC;
  --surface-3:     #EDF1F8;
  --border:        #E2E7F0;
  --border-soft:   #EDF1F7;
  --line:          rgba(12,27,51,.06);

  /* Tinta — quase preto com leve viés navy (família da marca) */
  --ink:           #0C1B33;
  --ink-2:         #1E2D47;
  --muted:         #66728A;
  --dim:           #8C97AC;
  --faint:         #B4BCCD;

  /* Marca — azul elétrico Tovix */
  --accent:        #0A6CF0;
  --accent-2:      #2E97FF;
  --accent-strong: #0050D6;
  --accent-grad:   linear-gradient(135deg, #2E97FF 0%, #0A6CF0 52%, #0050D6 100%);
  --accent-soft:   linear-gradient(135deg, #5FB0FF 0%, #1E7CFF 100%);
  --accent-tint:   #E9F2FF;
  --accent-tint-2: #DCEBFF;
  --accent-line:   #CBE0FF;
  --on-accent:     #FFFFFF;

  /* Navy profundo da marca — usado em superfícies escuras */
  --navy:          #0A1A33;
  --navy-2:        #0E2347;
  --navy-3:        #16315E;

  /* Status — vivos, inspiradores, mas calibrados */
  --ok:            #0FA968;
  --ok-2:          #12C078;
  --ok-tint:       #E2F7EE;
  --warn:          #E08600;
  --warn-tint:     #FCF0DA;
  --danger:        #E5484D;
  --danger-tint:   #FCE9EA;
  --info:          #0A6CF0;
  --info-tint:     #E9F2FF;

  /* Elevação suave (Apple-like) */
  --shadow-1: 0 1px 2px rgba(12,27,51,.06), 0 1px 1px rgba(12,27,51,.03);
  --shadow-2: 0 4px 14px -4px rgba(12,27,51,.10), 0 14px 38px -14px rgba(12,27,51,.16);
  --shadow-3: 0 8px 30px -8px rgba(12,27,51,.18);
  --shadow-glow: 0 8px 22px -6px rgba(10,108,240,.42);
  --shadow-drawer: -28px 0 70px -24px rgba(12,27,51,.24);

  /* Raios generosos */
  --r-sm: 8px;  --r-md: 12px;  --r-lg: 16px;  --r-xl: 22px;  --r-2xl: 28px;

  --sidebar-w: 248px;
  --row-h: 50px;
  --pad-y: 16px;

  --font-sans:    "Geist", -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", "Helvetica Neue", sans-serif;
  --font-display: "Geist", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", sans-serif;
  --font-mono:    "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* Variantes de paleta (todas com viés "sucesso/confiança") */
html[data-palette="ocean"] { --accent:#0A6CF0; --accent-2:#2E97FF; --accent-strong:#0050D6; --accent-grad:linear-gradient(135deg,#2E97FF,#0A6CF0 52%,#0050D6); --accent-tint:#E9F2FF; --accent-line:#CBE0FF; }
html[data-palette="azure"] { --accent:#0091E0; --accent-2:#2BB7FF; --accent-strong:#006BB0; --accent-grad:linear-gradient(135deg,#2BB7FF,#0091E0 55%,#006BB0); --accent-tint:#E4F5FF; --accent-line:#C2E8FF; }
html[data-palette="violet"]{ --accent:#5B5BF0; --accent-2:#8A7CFF; --accent-strong:#3E3ED0; --accent-grad:linear-gradient(135deg,#8A7CFF,#5B5BF0 55%,#3E3ED0); --accent-tint:#EDECFF; --accent-line:#D7D4FF; }
html[data-palette="emerald"]{ --accent:#0FA968; --accent-2:#22C57E; --accent-strong:#0A7F4F; --accent-grad:linear-gradient(135deg,#22C57E,#0FA968 55%,#0A7F4F); --accent-tint:#E2F7EE; --accent-line:#BFEAD4; }
/* compat antigo */
html[data-palette="sage"], html[data-palette="slate"], html[data-palette="clay"], html[data-palette="plum"]{ --accent:#0A6CF0; --accent-2:#2E97FF; --accent-strong:#0050D6; --accent-grad:linear-gradient(135deg,#2E97FF,#0A6CF0 52%,#0050D6); --accent-tint:#E9F2FF; --accent-line:#CBE0FF; }

/* Densidade */
html[data-density="cozy"]    { --row-h:58px; --pad-y:20px; }
html[data-density="regular"] { --row-h:50px; --pad-y:16px; }
html[data-density="compact"] { --row-h:42px; --pad-y:12px; }

/* Reset */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-sans);
  font-feature-settings:"ss01","cv11","cv02";
  color:var(--ink);
  background:
    radial-gradient(1100px 620px at 86% -8%, rgba(46,151,255,.10), transparent 60%),
    radial-gradient(900px 500px at -6% 8%, rgba(10,80,214,.06), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-size:14px; line-height:1.45; letter-spacing:-.006em;
}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
a{color:inherit;text-decoration:none}
input,textarea,select{font:inherit;color:inherit}
svg{display:block}
::selection{background:var(--accent-tint-2);color:var(--accent-strong)}

/* App shell */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

/* ───── Sidebar ───── */
.sb{
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  backdrop-filter:saturate(180%) blur(20px);
  border-right:1px solid var(--border);
  padding:18px 14px;display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
}
.sb-brand{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:8px 8px 20px}
.sb-logo{width:100%;max-width:190px;height:auto;display:block}
.sb-tagline{font-size:9.5px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted);line-height:1.4;padding-left:2px}
.sb-mark{
  width:40px;height:40px;border-radius:12px;background:var(--navy);
  display:none;place-items:center;position:relative;flex-shrink:0;overflow:hidden;
  box-shadow:0 4px 12px -4px rgba(10,26,51,.5), inset 0 1px 0 rgba(255,255,255,.08);
}
.sb-mark img{width:100%;height:100%;object-fit:cover;display:block}
.sb-sect{font-size:10.5px;font-weight:600;color:var(--dim);
  text-transform:uppercase;letter-spacing:.09em;padding:16px 12px 7px}
.sb-nav{display:flex;flex-direction:column;gap:2px}
.sb-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:11px;
  color:var(--ink-2);font-size:13.5px;font-weight:500;position:relative;
  transition:background .18s var(--ease),color .18s var(--ease),transform .12s var(--ease)}
.sb-item:hover{background:var(--surface-3)}
.sb-item:active{transform:scale(.98)}
.sb-item.active{
  background:linear-gradient(135deg, rgba(46,151,255,.14), rgba(10,108,240,.10));
  color:var(--accent-strong);font-weight:600;
  box-shadow:inset 0 0 0 1px var(--accent-line);
}
.sb-item .ico{width:17px;height:17px;flex:0 0 17px;color:var(--muted);transition:color .18s}
.sb-item.active .ico{color:var(--accent)}
.sb-item .ico svg{width:100%;height:100%}
.sb-item .count{margin-left:auto;font-size:11px;color:var(--dim);font-variant-numeric:tabular-nums}
.sb-item.active .count{color:var(--accent)}
.sb-foot{margin-top:auto;padding:12px 10px 4px;border-top:1px solid var(--border-soft);
  display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:50%;
  background:var(--accent-grad);color:#fff;
  display:grid;place-items:center;font-size:12.5px;font-weight:600;
  box-shadow:var(--shadow-glow);flex-shrink:0;letter-spacing:.01em}
.sb-user{display:flex;flex-direction:column;line-height:1.18;min-width:0}
.sb-user b{font-size:13px;font-weight:600;color:var(--ink)}
.sb-user span{font-size:11px;color:var(--muted);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}

/* ───── Main / Topbar ───── */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 30px;
  background:rgba(238,241,247,.72);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:5}
.crumbs{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px}
.crumbs b{color:var(--ink);font-weight:600}
.crumbs .sep{color:var(--faint)}
.search{position:relative;margin-left:auto;display:flex;align-items:center;
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:8px 12px 8px 34px;width:300px;
  box-shadow:var(--shadow-1);
  transition:border-color .18s,box-shadow .18s}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-tint)}
.search .ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;color:var(--dim)}
.search input{background:transparent;border:0;outline:0;width:100%;font-size:13px}
.search input::placeholder{color:var(--dim)}
.kbd{font-family:var(--font-mono);font-size:10.5px;padding:2px 6px;border-radius:6px;
  background:var(--surface-3);color:var(--muted);border:1px solid var(--border);margin-left:6px}
.icon-btn{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;
  color:var(--muted);border:1px solid var(--border);background:var(--surface);
  position:relative;box-shadow:var(--shadow-1);
  transition:background .18s,color .18s,transform .12s;flex-shrink:0}
.icon-btn:hover{color:var(--accent);background:var(--surface)}
.icon-btn:active{transform:scale(.96)}
.icon-btn .ico{width:15px;height:15px}
.icon-btn .dot{position:absolute;top:7px;right:7px;width:7px;height:7px;
  border-radius:50%;background:var(--danger);border:2px solid var(--surface)}

/* ───── Page header ───── */
.page{padding:30px 30px 72px;max-width:1500px;width:100%}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;
  gap:20px;margin-bottom:26px;flex-wrap:wrap}
.page-title{font-family:var(--font-display);font-weight:600;
  font-size:30px;letter-spacing:-.03em;margin:0 0 5px;color:var(--ink);line-height:1.08}
.page-sub{color:var(--muted);font-size:13.5px;margin:0;max-width:640px}
.page-actions{display:flex;gap:9px;align-items:center}

/* ───── Buttons ───── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;
  border-radius:11px;font-size:13px;font-weight:600;letter-spacing:-.01em;
  border:1px solid var(--border);background:var(--surface);color:var(--ink);
  box-shadow:var(--shadow-1);
  transition:background .16s,border-color .16s,transform .12s,box-shadow .16s}
.btn:hover{background:var(--surface-2);border-color:var(--accent-line)}
.btn:active{transform:scale(.97)}
.btn.primary{background:var(--accent-grad);color:var(--on-accent);
  border-color:transparent;box-shadow:var(--shadow-glow)}
.btn.primary:hover{filter:brightness(1.05);border-color:transparent}
.btn.ghost{border-color:transparent;background:transparent;color:var(--muted);box-shadow:none}
.btn.ghost:hover{background:var(--surface-3);color:var(--ink)}
.btn.sm{padding:6px 10px;font-size:12px;border-radius:9px}
.btn .ico{width:14px;height:14px}

/* ───── Cards ───── */
.card{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-1);overflow:hidden;
  transition:box-shadow .2s var(--ease)}
.card-pad{padding:22px}
.card-head{padding:18px 22px;border-bottom:1px solid var(--border-soft);
  display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.018em}
.card-sub{font-size:12px;color:var(--muted);margin-top:3px}

/* ───── KPI ───── */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.kpis-3{grid-template-columns:repeat(3,1fr)}
.kpi{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:20px;display:flex;flex-direction:column;gap:7px;
  box-shadow:var(--shadow-1);position:relative;overflow:hidden;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--accent-grad);opacity:0;transition:opacity .2s}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}
.kpi:hover::before{opacity:1}
.kpi-label{display:flex;align-items:center;gap:8px;font-size:12px;
  color:var(--muted);font-weight:500}
.kpi-label .ico{width:15px;height:15px;color:var(--accent)}
.kpi-value{font-family:var(--font-display);font-weight:600;font-size:33px;
  letter-spacing:-.035em;font-variant-numeric:tabular-nums;line-height:1.02;margin-top:3px;color:var(--ink)}
.kpi-foot{display:flex;align-items:center;gap:8px;font-size:11.5px;
  color:var(--muted);margin-top:7px}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;
  padding:3px 7px;border-radius:7px;font-variant-numeric:tabular-nums}
.delta.up{background:var(--ok-tint);color:var(--ok)}
.delta.down{background:var(--danger-tint);color:var(--danger)}
.delta.flat{background:var(--surface-3);color:var(--muted)}
.delta .ico{width:11px;height:11px}
.kpi-spark{position:absolute;right:16px;top:16px;width:66px;height:26px;opacity:.85}

/* KPI destaque (primeira card) */
.kpi.feature{background:linear-gradient(150deg,var(--navy) 0%,var(--navy-2) 60%,var(--navy-3) 100%);
  border-color:transparent;color:#fff;box-shadow:var(--shadow-2)}
.kpi.feature::before{display:none}
.kpi.feature .kpi-label{color:rgba(255,255,255,.72)}
.kpi.feature .kpi-label .ico{color:var(--accent-2)}
.kpi.feature .kpi-value{color:#fff}
.kpi.feature .kpi-foot{color:rgba(255,255,255,.6)}
.kpi.feature::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;
  border-radius:50%;background:radial-gradient(circle,rgba(46,151,255,.4),transparent 70%);pointer-events:none}

/* ───── Grid ───── */
.grid-2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;margin-bottom:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ───── Funnel ───── */
.funnel{display:flex;flex-direction:column;gap:13px;padding:20px 22px 24px}
.funnel-row{display:flex;align-items:center;gap:14px}
.funnel-label{width:168px;display:flex;flex-direction:column;gap:1px;flex-shrink:0}
.funnel-label b{font-size:13px;font-weight:600}
.funnel-label span{font-size:11px;color:var(--muted)}
.funnel-bar-wrap{flex:1;display:flex;align-items:center;gap:10px}
.funnel-bar{height:26px;border-radius:9px;background:var(--accent-grad);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25);min-width:8px;
  transition:width .6s var(--ease)}
.funnel-bar.muted{background:var(--accent-tint-2);box-shadow:none}
.funnel-num{font-family:var(--font-mono);font-size:12px;color:var(--ink);font-weight:500;
  font-variant-numeric:tabular-nums;min-width:60px}
.funnel-pct{font-size:11px;color:var(--muted);min-width:44px;text-align:right;font-weight:500}

/* ───── Activity feed ───── */
.feed{display:flex;flex-direction:column;padding:6px 0}
.feed-item{display:flex;gap:13px;padding:13px 22px;border-bottom:1px solid var(--border-soft);
  transition:background .15s}
.feed-item:last-child{border-bottom:0}
.feed-item:hover{background:var(--surface-2)}
.feed-icon{flex:0 0 32px;width:32px;height:32px;border-radius:10px;
  background:var(--accent-tint);color:var(--accent);
  display:grid;place-items:center}
.feed-icon .ico{width:14px;height:14px}
.feed-icon.warn{background:var(--warn-tint);color:var(--warn)}
.feed-icon.ok{background:var(--ok-tint);color:var(--ok)}
.feed-icon.danger{background:var(--danger-tint);color:var(--danger)}
.feed-body{min-width:0;flex:1}
.feed-line{font-size:13px;color:var(--ink-2)}
.feed-line b{font-weight:600;color:var(--ink)}
.feed-meta{font-size:11.5px;color:var(--muted);margin-top:2px}

/* ───── Toolbar / tabs ───── */
.toolbar{display:flex;align-items:center;gap:8px;padding:14px 18px;
  border-bottom:1px solid var(--border-soft);flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;
  border-radius:9px;font-size:12px;font-weight:500;color:var(--muted);
  background:var(--surface-2);border:1px solid var(--border-soft);transition:all .15s}
.chip:hover{color:var(--ink);background:var(--surface-3)}
.chip.active{background:var(--accent-tint);color:var(--accent-strong);border-color:var(--accent-line)}
.chip .ico{width:11px;height:11px}
.chip .x{color:var(--dim);margin-left:2px;font-size:14px;line-height:0}
.tabs{display:flex;gap:3px;background:var(--surface-3);
  border:1px solid var(--border-soft);border-radius:11px;padding:3px}
.tab{padding:6px 13px;font-size:12.5px;font-weight:500;color:var(--muted);border-radius:8px;
  transition:all .18s var(--ease);display:inline-flex;align-items:center;gap:6px}
.tab .num{font-family:var(--font-mono);font-size:10.5px;color:var(--dim);
  padding:1px 5px;border-radius:5px;background:var(--surface)}
.tab:hover{color:var(--ink)}
.tab.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-1);font-weight:600}
.tab.active .num{color:var(--accent);background:var(--accent-tint)}

/* ───── Table ───── */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{text-align:left;font-weight:600;font-size:11px;color:var(--dim);
  text-transform:uppercase;letter-spacing:.06em;padding:12px 18px;
  border-bottom:1px solid var(--border-soft);background:var(--surface-2);
  position:sticky;top:0}
.tbl tbody td{padding:0 18px;height:var(--row-h);
  border-bottom:1px solid var(--border-soft);vertical-align:middle}
.tbl tbody tr{cursor:pointer;transition:background .14s}
.tbl tbody tr:hover{background:var(--accent-tint)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr.selected{background:var(--accent-tint)}
.tbl .num{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.tbl .lead-name{display:flex;align-items:center;gap:11px}
.tbl .lead-name b{font-weight:600}
.tbl .lead-name span{font-size:11.5px;color:var(--muted);display:block;margin-top:1px}

/* ───── Badges ───── */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;
  padding:4px 10px;border-radius:20px;background:var(--surface-3);color:var(--muted);
  white-space:nowrap;line-height:1.4}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge.novo{color:var(--info);background:var(--info-tint)}
.badge.atendimento{color:var(--accent-strong);background:var(--accent-tint)}
.badge.qualificado{color:var(--ok);background:var(--ok-tint)}
.badge.atrasado{color:var(--danger);background:var(--danger-tint)}
.badge.proposta{color:var(--warn);background:var(--warn-tint)}
.badge.vendido{color:var(--ok);background:var(--ok-tint)}
.badge.perdido{color:var(--muted);background:var(--surface-3)}
.badge.ok{color:var(--ok);background:var(--ok-tint)}
.badge.plain{background:var(--surface-3);color:var(--muted);padding:3px 9px;font-size:11px;border-radius:8px}
.badge.plain::before{display:none}
.badge .ico{width:10px;height:10px}

/* ───── SLA ring ───── */
.sla{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.sla-ring{--p:60;width:20px;height:20px;border-radius:50%;
  background:conic-gradient(currentColor calc(var(--p)*1%),var(--surface-3) 0);position:relative}
.sla-ring::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--surface)}
.sla.ok{color:var(--ok)}
.sla.warn{color:var(--warn)}
.sla.danger{color:var(--danger)}

/* ───── Drawer ───── */
.drawer-scrim{position:fixed;inset:0;background:rgba(12,27,51,.28);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;
  opacity:0;pointer-events:none;transition:opacity .22s}
.drawer-scrim.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:580px;max-width:92vw;
  background:var(--surface);border-left:1px solid var(--border);
  box-shadow:var(--shadow-drawer);z-index:51;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .3s var(--ease)}
.drawer.open{transform:translateX(0)}
.drawer-head{padding:20px 24px 16px;border-bottom:1px solid var(--border-soft);
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.drawer-body{flex:1;overflow-y:auto;padding:20px 24px 36px}
.drawer-foot{padding:16px 24px;border-top:1px solid var(--border-soft);
  display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--surface-2)}
.lead-h1{font-family:var(--font-display);font-weight:600;font-size:23px;
  letter-spacing:-.025em;margin:0 0 4px}
.lead-meta{font-size:12.5px;color:var(--muted);display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.lead-meta .ico{width:11px;height:11px;display:inline-block;vertical-align:-1px;margin-right:3px}
.lead-meta .dotsep{color:var(--faint)}
.sect{margin-top:24px}
.sect-h{font-size:10.5px;font-weight:700;color:var(--dim);
  text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}
.kv{display:grid;grid-template-columns:120px 1fr;gap:6px 14px;font-size:13px;margin:0}
.kv dt{color:var(--muted);font-weight:500}
.kv dd{margin:0;color:var(--ink)}
.timeline{display:flex;flex-direction:column;position:relative}
.tl{display:flex;gap:12px;padding:0 0 16px;position:relative}
.tl::before{content:"";position:absolute;left:13px;top:26px;bottom:-2px;width:2px;background:var(--border)}
.tl:last-child::before{display:none}
.tl-dot{width:28px;height:28px;flex:0 0 28px;border-radius:50%;
  background:var(--accent-tint);border:none;
  display:grid;place-items:center;color:var(--accent);position:relative;z-index:1}
.tl-dot.muted{background:var(--surface-3);color:var(--dim)}
.tl-dot.ok{background:var(--ok-tint);color:var(--ok)}
.tl-dot.warn{background:var(--warn-tint);color:var(--warn)}
.tl-dot .ico{width:13px;height:13px}
.tl-body{flex:1;padding-top:3px}
.tl-line{font-size:13px;color:var(--ink-2)}
.tl-line b{font-weight:600}
.tl-meta{font-size:11.5px;color:var(--muted);margin-top:3px;font-family:var(--font-mono)}
.sla-card{background:var(--surface-2);border:1px solid var(--border-soft);
  border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:14px}
.big-ring{--p:60;width:52px;height:52px;border-radius:50%;
  background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--accent-line) 0);
  position:relative;flex:0 0 52px}
.big-ring::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--surface-2)}
.big-ring span{position:absolute;inset:0;display:grid;place-items:center;
  font-size:12px;font-weight:700;color:var(--accent);
  font-family:var(--font-mono);font-variant-numeric:tabular-nums}

/* ───── Empreendimentos cards ───── */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.proj{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-1);
  display:flex;flex-direction:column;transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.proj:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.proj-img{height:150px;
  background:linear-gradient(135deg,var(--navy),var(--navy-3));
  position:relative;display:grid;place-items:center;color:rgba(255,255,255,.5);
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}
.proj-img::after{content:"";position:absolute;inset:0;
  background:radial-gradient(420px 200px at 80% -20%,rgba(46,151,255,.35),transparent 70%)}
.proj-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:8px}
.proj-name{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.018em}
.proj-loc{font-size:12px;color:var(--muted)}
.proj-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
  padding-top:12px;border-top:1px solid var(--border-soft);margin-top:4px}
.stat-l{font-size:10.5px;color:var(--dim);text-transform:uppercase;letter-spacing:.06em}
.stat-v{font-family:var(--font-mono);font-size:13px;font-variant-numeric:tabular-nums;margin-top:1px;font-weight:500}

/* ───── Logs / Audit ───── */
.log{display:flex;align-items:center;gap:14px;padding:12px 22px;
  border-bottom:1px solid var(--border-soft);font-size:12.5px;transition:background .14s}
.log:hover{background:var(--surface-2)}
.log:last-child{border-bottom:0}
.log .ts{font-family:var(--font-mono);font-size:11.5px;color:var(--muted);width:140px;flex:0 0 140px}
.log .who{display:flex;align-items:center;gap:8px;width:200px;flex:0 0 200px}
.log .who b{font-weight:600;font-size:12.5px}
.log .who .small{font-size:11px;color:var(--muted)}
.log .act{flex:1;color:var(--ink-2)}
.log .act code{font-family:var(--font-mono);font-size:11.5px;
  padding:2px 6px;border-radius:6px;background:var(--surface-3);color:var(--accent-strong)}

/* ───── Placeholder ───── */
.ph-stripe{background:repeating-linear-gradient(135deg,var(--surface-3) 0 8px,var(--surface-2) 8px 9px);
  border:1px dashed var(--border);border-radius:var(--r-md);color:var(--dim);
  font-family:var(--font-mono);font-size:11px;display:grid;place-items:center;
  text-transform:uppercase;letter-spacing:.06em}

/* ───── Utils ───── */
.sep-v{width:1px;background:var(--border);height:18px;margin:0 4px;align-self:center}
.spacer{flex:1}
.row{display:flex;align-items:center;gap:8px}
.col{display:flex;flex-direction:column;gap:8px}
.muted{color:var(--muted)}
.dim{color:var(--dim)}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.ranking-row{display:flex;align-items:center;gap:14px;padding:13px 22px;
  border-bottom:1px solid var(--border-soft)}
.ranking-row:last-child{border-bottom:0}
.ranking-bar{width:64px;height:6px;border-radius:6px;background:var(--surface-3);overflow:hidden}
.ranking-bar > div{height:100%;background:var(--accent-grad)}

/* ───── Tweaks panel ───── */
.tw-toggle{position:fixed;right:18px;bottom:18px;z-index:60;
  width:44px;height:44px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);
  box-shadow:var(--shadow-2);display:grid;place-items:center;color:var(--accent);
  transition:transform .15s}
.tw-toggle:hover{transform:scale(1.06)}
.tw-toggle .ico{width:18px;height:18px}
.tw-panel{position:fixed;right:18px;bottom:72px;z-index:60;width:284px;
  background:var(--surface);border:1px solid var(--border);border-radius:18px;
  box-shadow:var(--shadow-3);padding:16px;display:none}
.tw-panel.open{display:block}
.tw-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.tw-hd b{font-family:var(--font-display);font-size:14px;font-weight:600}
.tw-row{display:flex;flex-direction:column;gap:6px;margin-top:14px}
.tw-row > label{font-size:11px;color:var(--muted);font-weight:600;
  text-transform:uppercase;letter-spacing:.06em}
.tw-seg{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:3px;
  background:var(--surface-3);border:1px solid var(--border-soft);border-radius:10px;padding:3px}
.tw-seg button{padding:7px;font-size:11.5px;color:var(--muted);
  border-radius:7px;transition:all .15s;font-weight:600}
.tw-seg button:hover{color:var(--ink)}
.tw-seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-1)}
.tw-swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.tw-sw{height:36px;border-radius:10px;border:1px solid var(--border-soft);
  cursor:pointer;position:relative;transition:transform .15s}
.tw-sw:hover{transform:translateY(-2px)}
.tw-sw.active::after{content:"";position:absolute;inset:-3px;border:2px solid var(--ink);border-radius:13px}
.tw-sw[data-p="ocean"]  {background:linear-gradient(135deg,#2E97FF,#0050D6)}
.tw-sw[data-p="azure"]  {background:linear-gradient(135deg,#2BB7FF,#006BB0)}
.tw-sw[data-p="violet"] {background:linear-gradient(135deg,#8A7CFF,#3E3ED0)}
.tw-sw[data-p="emerald"]{background:linear-gradient(135deg,#22C57E,#0A7F4F)}
/* compat antigo */
.tw-sw[data-p="sage"]  {background:linear-gradient(135deg,#2E97FF,#0050D6)}
.tw-sw[data-p="slate"] {background:linear-gradient(135deg,#2BB7FF,#006BB0)}
.tw-sw[data-p="clay"]  {background:linear-gradient(135deg,#8A7CFF,#3E3ED0)}
.tw-sw[data-p="plum"]  {background:linear-gradient(135deg,#22C57E,#0A7F4F)}

/* Responsive */
@media (max-width:1024px){
  .app{grid-template-columns:68px 1fr}
  .sb{padding:14px 10px}
  .sb-sect,.sb-item .lbl,.sb-item .count,.sb-user,.sb-logo,.sb-tagline{display:none}
  .sb-mark{display:grid}
  .sb-item{justify-content:center;padding:10px}
  .sb-brand{align-items:center;padding:6px 0 18px}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   Flash messages
   ============================================================ */
.flash-stack{position:fixed;top:18px;right:18px;z-index:9999;display:flex;
  flex-direction:column;gap:10px;max-width:390px}
.flash{display:flex;align-items:center;gap:11px;padding:14px 16px;border-radius:13px;
  background:rgba(255,255,255,.85);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border:1px solid var(--border);box-shadow:var(--shadow-2);font-size:13.5px;color:var(--ink);
  animation:flashIn .3s var(--ease)}
.flash .ico{width:18px;height:18px;flex-shrink:0}
.flash-x{margin-left:auto;background:none;border:0;cursor:pointer;font-size:18px;
  color:var(--muted);padding:0 4px;line-height:1}
.flash-success{border-left:4px solid var(--ok)}
.flash-success .ico{color:var(--ok)}
.flash-error{border-left:4px solid var(--danger)}
.flash-error .ico{color:var(--danger)}
.flash-warning{border-left:4px solid var(--warn)}
.flash-info{border-left:4px solid var(--info)}
.flash-info .ico{color:var(--info)}
@keyframes flashIn{from{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ============================================================
   Login
   ============================================================ */
.login-body{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  font-family:var(--font-sans);color:var(--ink);
  background:
    radial-gradient(900px 600px at 80% 10%, rgba(46,151,255,.18), transparent 60%),
    radial-gradient(700px 500px at 10% 90%, rgba(10,80,214,.14), transparent 60%),
    var(--bg);
}
.login-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:940px;width:100%;
  background:var(--surface);border-radius:var(--r-2xl);overflow:hidden;
  box-shadow:var(--shadow-2);border:1px solid var(--border)}
.login-card{padding:44px 46px;display:flex;flex-direction:column;gap:18px}
.login-brand{display:flex;align-items:center;gap:13px}
.login-title{font-family:var(--font-display);font-size:30px;margin:6px 0 0;color:var(--ink);
  font-weight:600;letter-spacing:-.03em}
.login-sub{color:var(--muted);font-size:14px;margin:0 0 8px}
.login-form{display:flex;flex-direction:column;gap:15px}
.login-foot{margin-top:14px;text-align:center;font-size:12px;color:var(--dim)}
.login-side{position:relative;overflow:hidden;color:#fff;padding:46px;
  display:flex;flex-direction:column;justify-content:center;
  background:linear-gradient(155deg,var(--navy) 0%,var(--navy-2) 55%,var(--navy-3) 100%)}
.login-side::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;
  border-radius:50%;background:radial-gradient(circle,rgba(46,151,255,.45),transparent 70%);pointer-events:none}
.login-side-title{font-family:var(--font-display);font-size:28px;margin:0 0 16px;
  line-height:1.18;font-weight:600;letter-spacing:-.03em;position:relative}
.login-side-sub{font-size:14px;line-height:1.6;opacity:.82;margin:0;position:relative}
.login-logo{width:210px;max-width:66%;height:auto;display:block}
.login-tagline{font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);margin:12px 0 0}
.login-side .login-logo{width:240px;max-width:72%;margin-bottom:22px;position:relative}
.login-side .login-tagline{color:rgba(255,255,255,.72);margin-top:18px;position:relative}
@media (max-width:720px){.login-wrap{grid-template-columns:1fr}.login-side{display:none}}

/* Filtros */
.filters-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding:16px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);
  box-shadow:var(--shadow-1);margin-bottom:16px}
.field.inline{min-width:140px;flex:0 1 auto}
.field.inline span{font-size:11px;color:var(--muted)}
.field.inline input,.field.inline select{padding:8px 11px;font-size:13px}

/* Forms */
.form-card{display:flex;flex-direction:column;gap:14px;padding:20px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:680px){.form-grid{grid-template-columns:1fr}}
.form-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center;
  padding-top:14px;border-top:1px solid var(--border-soft);margin-top:6px}
.btn.block{width:100%;justify-content:center;padding:13px 18px;font-size:14px;font-weight:600}

/* Sidebar logout */
.sb-logout{margin-left:auto;padding:7px;border-radius:9px;color:var(--dim);
  display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.sb-logout:hover{background:var(--danger-tint);color:var(--danger)}
.sb-logout .ico{width:15px;height:15px}

/* Note */
.note{background:var(--accent-tint);border-left:3px solid var(--accent);
  padding:13px 15px;border-radius:10px;font-size:13.5px;line-height:1.55;color:var(--ink-2)}

/* Container principal */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;
  gap:20px;margin-bottom:24px;flex-wrap:wrap}
.page-actions{display:flex;gap:9px;align-items:center;flex-shrink:0}

/* FIELD */
.field{display:flex;flex-direction:column;gap:6px;font-size:12.5px}
.field > span{font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:.002em}
.field input[type=text],.field input[type=email],.field input[type=password],
.field input[type=number],.field input[type=tel],.field input[type=url],
.field input[type=search],.field select,.field textarea{
  width:100%;padding:11px 13px;font-size:13.5px;font-family:var(--font-sans);color:var(--ink);
  background:var(--surface-2);border:1px solid var(--border);border-radius:11px;outline:none;
  transition:border-color .16s,box-shadow .16s,background .16s;box-sizing:border-box}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px var(--accent-tint)}
.field input:disabled,.field select:disabled{background:var(--surface-3);color:var(--muted);cursor:not-allowed}
.field textarea{resize:vertical;min-height:84px;line-height:1.5}
.field select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%2366728A' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
.field.check{display:flex !important;flex-direction:row !important;align-items:center !important;gap:8px !important}
.field.check > span{color:var(--ink);font-size:13px;font-weight:400}
.field.check input[type=checkbox]{width:18px;height:18px;margin:0;accent-color:var(--accent)}

/* Grid de 2 colunas */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:880px){.grid-2{grid-template-columns:1fr}}

/* Tabela (reforço) */
.lead-name{display:inline-flex;align-items:center;gap:11px;text-decoration:none;color:inherit}
.lead-name > div{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.lead-name b{font-weight:600;color:var(--ink);font-size:13px}
.lead-name span{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* KV / timeline / avatar (reforço) */
.kv{display:grid;grid-template-columns:160px 1fr;gap:10px 14px;margin:0;padding:4px 2px}
.kv dt{font-size:12px;color:var(--muted);font-weight:500}
.kv dd{margin:0;font-size:13px;color:var(--ink)}

/* Login reforço */
.login-body *{box-sizing:border-box}
.login-body .field span,.login-body label.field > span{font-size:11.5px;color:var(--muted);font-weight:600}

.lead-name-simple{display:inline-flex;align-items:center;text-decoration:none;color:inherit}
.lead-name-simple > div{display:flex;flex-direction:column;line-height:1.3;min-width:0}
.lead-name-simple b{font-weight:600;color:var(--ink);font-size:13px}
.lead-name-simple span{font-size:11.5px;color:var(--muted)}

/* Form sections */
.form-section{padding:16px 0;border-bottom:1px solid var(--border-soft)}
.form-section:last-of-type{border-bottom:0;padding-bottom:4px}
.form-section:first-of-type{padding-top:4px}
.form-section-title{font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--dim);margin-bottom:12px}

/* Entrada animada das views */
.page > *{animation:rise .5s var(--ease) both}
.page > *:nth-child(2){animation-delay:.04s}
.page > *:nth-child(3){animation-delay:.08s}
.page > *:nth-child(4){animation-delay:.12s}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}
