/* === DASHBOARD === */
/* ── DASHBOARD ── */
/* Cards de stats padronizados (Vendas, Relatórios-agenda) — mesmo visual dos KPIs do dashboard */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}
.stat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:16px;
  padding:16px 14px;min-width:0;position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px -12px rgba(122,45,114,.18);border-color:var(--border2)}
.stat-icon{font-size:20px;margin-bottom:6px}
.stat-label{font-size:10.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:.03em;font-weight:600;margin-bottom:4px;line-height:1.2;max-width:100%;overflow-wrap:anywhere}
.stat-value{font-size:clamp(18px,2.2vw,25px);font-weight:700;color:var(--txt);line-height:1.1;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stat-sub{font-size:10.5px;color:var(--txt3);margin-top:4px;line-height:1.3;max-width:100%}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sec-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.sec-head{padding:11px 14px;border-bottom:1px solid var(--border);font-size:12px;font-weight:500;color:var(--txt);display:flex;align-items:center;gap:7px}
.sec-head i{color:var(--primary);font-size:14px}
.ag-item{padding:9px 14px;border-bottom:1px solid var(--border);display:flex;gap:9px;align-items:flex-start}
.ag-item:last-child{border-bottom:none}
.ag-time{font-size:10px;color:var(--txt3);min-width:36px;padding-top:1px}
.ag-info{flex:1}
.ag-client{font-size:12.5px;font-weight:500;color:var(--txt)}
.ag-proc{font-size:11px;color:var(--txt2)}
.spill{font-size:10px;font-weight:500;padding:2px 8px;border-radius:20px;white-space:nowrap;align-self:center}
.sc{background:#eaf3de;color:#3b6d11}.sp{background:#faeeda;color:#854f0b}.sk{background:#fcebeb;color:#a32d2d}
.cli-chip{padding:8px 14px;border-bottom:1px solid var(--border);display:flex;gap:9px;align-items:center;font-size:12px}
.cli-chip:last-child{border-bottom:none}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary-l);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}

/* ── DASHBOARD V2 (redesign) ── */
.dash-hero{
  position:relative;
  background:linear-gradient(135deg,var(--primary-d) 0%,var(--primary) 55%,var(--rose) 110%);
  border-radius:14px;padding:22px 26px;margin-bottom:18px;
  color:#fff;overflow:hidden;
  box-shadow:0 8px 24px -10px rgba(122,45,114,.45);
}
.dash-hero::before{
  content:"";position:absolute;top:-40px;right:-40px;width:220px;height:220px;
  background:radial-gradient(circle,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 70%);
  pointer-events:none;
}
.dash-hero::after{
  content:"";position:absolute;bottom:-60px;left:30%;width:180px;height:180px;
  background:radial-gradient(circle,rgba(201,169,110,.22) 0%,rgba(201,169,110,0) 70%);
  pointer-events:none;
}
.dash-hero-row{position:relative;display:flex;align-items:center;gap:18px;z-index:1}
.dash-hero-icon{
  width:54px;height:54px;border-radius:14px;
  background:rgba(255,255,255,.18);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;font-size:24px;
  flex-shrink:0;
}
.dash-hero-text{flex:1;min-width:0}
.dash-hero-title{font-size:22px;font-weight:700;line-height:1.15;margin-bottom:4px}
.dash-hero-sub{font-size:12px;color:rgba(255,255,255,.78);letter-spacing:.01em}
.dash-hero-chip{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);
  padding:6px 12px;border-radius:20px;font-size:11px;font-weight:500;
  backdrop-filter:blur(4px);
}
.dash-hero-chip i{font-size:13px}

/* KPI cards V2 */
/* Cards de KPI — centralizados e responsivos (minmax(0,1fr) = encolhe e NUNCA estoura/cria scroll) */
.kpi-grid{
  display:flex;
  flex-wrap:nowrap;   /* nunca quebra linha — os cards sempre dividem 100% da largura */
  gap:14px;margin-bottom:20px;
}
.kpi-card{
  flex:1 1 0;         /* cresce igualmente, sem limite de largura */
  min-width:0;        /* permite encolher se precisar */
  background:var(--surface);border:1px solid var(--border);border-radius:16px;
  padding:18px 14px 16px;position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
}
.kpi-card:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 24px -12px rgba(122,45,114,.18);
  border-color:var(--border2);
}
.kpi-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--kpi-color,var(--primary));opacity:.9;
}
.kpi-head{display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.kpi-icon-pill{
  width:46px;height:46px;border-radius:14px;
  background:var(--kpi-bg,var(--primary-l));
  color:var(--kpi-color,var(--primary));
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.kpi-trend{
  display:inline-flex;align-items:center;gap:3px;
  font-size:10.5px;font-weight:600;
  padding:3px 8px;border-radius:20px;
  background:var(--teal-l);color:var(--teal);
}
.kpi-trend.down{background:#FCEBEB;color:#A32D2D}
.kpi-trend.neutral{background:var(--gray-l);color:var(--gray)}
.kpi-trend i{font-size:12px}
.kpi-label{font-size:10.5px;color:var(--txt3);text-transform:uppercase;letter-spacing:.03em;font-weight:600;margin-bottom:4px;line-height:1.2;max-width:100%;overflow-wrap:anywhere}
.kpi-value{font-size:clamp(18px,2.2vw,26px);font-weight:700;color:var(--txt);line-height:1.1;margin-bottom:6px;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kpi-foot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:100%}
.kpi-sub{font-size:11px;color:var(--txt2);line-height:1.35;max-width:100%}
/* Responsivo: no tablet/celular permite quebrar linha e cada card ocupa metade/tela inteira */
@media(max-width:900px){ .kpi-grid{flex-wrap:wrap} .kpi-grid .kpi-card{flex-basis:calc(50% - 7px)} }
@media(max-width:520px){ .kpi-grid .kpi-card{flex-basis:100%} }
.kpi-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:8px}
.kpi-bar-fill{height:100%;background:var(--kpi-color,var(--primary));border-radius:3px;transition:width .6s ease}

/* Section cards V2 */
.dash-two{display:grid;grid-template-columns:1.15fr 1fr;gap:16px;margin-bottom:20px}
/* Tablet/celular: empilha um embaixo do outro. Precisa estar AQUI (dashboard.css
   carrega depois do base.css) senão a regra de 2 colunas acima sobrescreve o
   responsivo do base.css e os cards ficam espremidos lado a lado. */
@media(max-width:900px){ .dash-two{grid-template-columns:1fr} }
.dash-sec{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  overflow:hidden;
}
.dash-sec-head{
  padding:14px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.dash-sec-title{
  display:flex;align-items:center;gap:9px;
  font-size:13px;font-weight:600;color:var(--txt);
}
.dash-sec-title i{
  width:26px;height:26px;border-radius:8px;
  background:var(--primary-l);color:var(--primary);
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.dash-sec-link{
  font-size:11px;color:var(--primary);cursor:pointer;font-weight:500;
  display:flex;align-items:center;gap:3px;
  padding:4px 8px;border-radius:6px;transition:background .15s;
}
.dash-sec-link:hover{background:var(--primary-l)}
.dash-sec-body{padding:6px 0}

/* Timeline de atendimentos */
.tl-item{
  display:grid;grid-template-columns:62px 1fr auto;gap:12px;align-items:center;
  padding:11px 18px;position:relative;cursor:pointer;
  transition:background .15s;
}
.tl-item:hover{background:var(--bg)}
.tl-item:not(:last-child)::after{
  content:"";position:absolute;left:31px;top:36px;bottom:-6px;
  width:2px;background:var(--border);
}
.tl-time{
  font-size:13px;font-weight:700;color:var(--txt);
  display:flex;align-items:center;gap:8px;
}
.tl-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--tl-color,var(--primary));
  box-shadow:0 0 0 3px var(--tl-ring,var(--primary-l));
  flex-shrink:0;
}
.tl-info{min-width:0}
.tl-client{font-size:13px;font-weight:500;color:var(--txt);line-height:1.2;margin-bottom:2px}
.tl-proc{font-size:11px;color:var(--txt2);display:flex;align-items:center;gap:5px}
.tl-proc i{font-size:11px;opacity:.6}
.tl-status{
  font-size:10px;font-weight:600;padding:3px 9px;border-radius:20px;
  white-space:nowrap;letter-spacing:.02em;
}
.tl-status.confirmed{background:#eaf3de;color:#3b6d11}
.tl-status.waiting{background:var(--amber-l);color:#854f0b}
.tl-status.canceled{background:#fcebeb;color:#a32d2d}

/* Clientes recentes V2 */
.recent-grid{padding:8px}
.recent-item{
  display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;
  cursor:pointer;transition:background .15s;
}
.recent-item:hover{background:var(--bg)}
.recent-av{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;flex-shrink:0;
  background:linear-gradient(135deg,var(--av-c1,var(--primary)) 0%,var(--av-c2,var(--rose)) 100%);
  box-shadow:0 2px 6px -2px rgba(122,45,114,.35);
}
.recent-info{flex:1;min-width:0}
.recent-name{font-size:12.5px;font-weight:500;color:var(--txt);line-height:1.2}
.recent-meta{font-size:10.5px;color:var(--txt3);display:flex;align-items:center;gap:6px;margin-top:2px}
.recent-meta-tag{
  font-size:9.5px;font-weight:600;padding:1.5px 7px;border-radius:20px;
  background:var(--accent-l);color:var(--amber);
}

/* Seção retornos V2 */
.dash-retorno{margin-top:6px}
.dash-retorno-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;gap:12px;
}
.dash-retorno-title{
  font-weight:700;font-size:17px;color:var(--txt);
  display:flex;align-items:center;gap:10px;
}
.dash-retorno-title i{
  width:30px;height:30px;border-radius:9px;
  background:var(--primary-l);color:var(--primary);
  display:flex;align-items:center;justify-content:center;font-size:15px;
}
.r-stat-v2{
  display:flex;align-items:center;gap:12px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:14px 16px;position:relative;overflow:hidden;
  transition:transform .18s,box-shadow .18s;
}
.r-stat-v2:hover{transform:translateY(-1px);box-shadow:0 6px 16px -10px rgba(122,45,114,.2)}
.r-stat-v2::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--rs-color);
}
.r-stat-v2-icon{
  width:38px;height:38px;border-radius:10px;
  background:var(--rs-bg);color:var(--rs-color);
  display:flex;align-items:center;justify-content:center;font-size:17px;
  flex-shrink:0;
}
.r-stat-v2-text{min-width:0}
.r-stat-v2-val{font-size:22px;font-weight:700;color:var(--rs-color);line-height:1}
.r-stat-v2-lbl{font-size:11px;color:var(--txt2);margin-top:3px}

/* ── Dashboard: WhatsApp inline (amanhã / aniversariantes) ── */
.dash-wpp{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:#25D36618;color:#1c9c4d;font-size:16px;text-decoration:none;
  transition:background .15s;
}
.dash-wpp:hover{background:#25D36633}

/* ── Dashboard: aniversariantes do mês ── */
.aniv-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}
.aniv-item{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--surface);
}
.aniv-item.aniv-hoje{
  border-color:var(--primary);
  background:var(--primary-l);
  box-shadow:0 0 0 1px var(--primary) inset;
}
.aniv-av{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;
  background:linear-gradient(135deg,var(--rose),var(--coral));color:#fff;
}
.aniv-info{flex:1;min-width:0}
.aniv-name{
  font-size:13px;font-weight:600;color:var(--txt);
  display:flex;align-items:center;gap:7px;flex-wrap:wrap;
}
.aniv-meta{font-size:11.5px;color:var(--txt2);margin-top:2px;display:flex;align-items:center;gap:5px}
.aniv-meta i{font-size:13px;color:var(--primary)}
.aniv-badge{
  font-size:10px;font-weight:700;color:var(--primary);
  background:#fff;border:1px solid var(--primary);
  padding:1px 7px;border-radius:20px;white-space:nowrap;
}
.aniv-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.aniv-sent{
  font-size:11px;font-weight:600;color:var(--teal);
  display:inline-flex;align-items:center;gap:4px;white-space:nowrap;
}
.aniv-sent i{font-size:14px}
@media(max-width:720px){ .aniv-grid{grid-template-columns:1fr} }

/* ── Dashboard "Confirmar amanhã": ações na mesma linha (status/confirmar/wpp) ── */
.dash-amanha-acoes{display:flex;align-items:center;gap:7px;flex-shrink:0}
.dash-conf-btn{
  display:inline-flex;align-items:center;gap:5px;white-space:nowrap;
  background:var(--teal-l,#ECF6F1);color:#1c7d56;
  border:1px solid #bfe3d3;border-radius:20px;
  padding:5px 11px;font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;
  transition:background .15s;
}
.dash-conf-btn:hover{background:#d8efe4}
.dash-conf-btn i{font-size:14px}

/* ── ASSESSOR · cobra pendências na tela inicial ── */
.assessor-card{
  background:linear-gradient(135deg,var(--sidebar-bg-1,#3d2235),var(--sidebar-bg-2,#5a3450));
  border-radius:var(--radius);box-shadow:var(--shadow-md);
  padding:16px 18px;margin-bottom:18px;color:#fff;
}
.assessor-head{display:flex;align-items:center;gap:12px}
.assessor-avatar{
  width:44px;height:44px;border-radius:13px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:23px;
  background:rgba(255,255,255,.14);color:var(--gold,#E3B23C);
}
.assessor-msg{flex:1;font-size:13.5px;line-height:1.5}
.assessor-msg b{color:var(--gold,#E3B23C);font-weight:700}
.assessor-refresh{
  background:rgba(255,255,255,.12);border:none;color:#fff;border-radius:9px;
  width:34px;height:34px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.assessor-refresh:hover{background:rgba(255,255,255,.24)}
.assessor-refresh i{font-size:16px}
.assessor-body{margin-top:14px;display:flex;flex-direction:column;gap:12px}
.assessor-body:empty{display:none}
.assessor-group{background:var(--surface);border-radius:var(--radius-sm);padding:10px 13px;color:var(--txt)}
.assessor-group-tit{
  font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.4px;
  margin-bottom:6px;display:flex;align-items:center;gap:6px;
}
.assessor-item{display:flex;align-items:center;gap:10px;padding:8px 4px;border-top:1px solid var(--border)}
.assessor-item:first-of-type{border-top:none}
.assessor-pill{font-size:10px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap;flex-shrink:0}
.assessor-empty{
  background:rgba(255,255,255,.12);border-radius:var(--radius-sm);padding:12px 14px;
  color:#fff;font-size:13px;display:flex;align-items:center;gap:9px;
}
@media (max-width:600px){
  .assessor-item{flex-wrap:wrap}
  .assessor-item>div:first-child{flex-basis:100%}
}
