:root{--bg:#f4f6f8;--panel:#fff;--text:#17202a;--muted:#6b7280;--primary:#176b45;--primary-2:#0f5132;--border:#e5e7eb;--warn:#f59e0b;--danger:#dc2626;--dark:#111827;--shadow:0 12px 30px rgba(15,23,42,.08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}.app-shell{display:flex;min-height:100vh}.sidebar{width:290px;background:#0f1f18;color:#fff;padding:22px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center}.brand-mark{width:44px;height:44px;border-radius:14px;background:#21a366;display:grid;place-items:center;font-weight:800}.brand h1{font-size:18px;margin:0}.brand span{font-size:12px;color:#b7c7be}.nav{display:grid;gap:8px}.nav-item{border:0;background:transparent;color:#d7e5dc;text-align:left;padding:12px 14px;border-radius:12px;cursor:pointer;font-weight:600}.nav-item.active,.nav-item:hover{background:rgba(255,255,255,.11)}.sidebar-footer{margin-top:auto;display:grid;gap:8px}.sidebar-footer label,.sidebar-footer small{color:#b7c7be;font-size:12px}.sidebar select{width:100%;padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#152920;color:#fff}.main{flex:1;padding:26px;overflow:auto}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:22px}.topbar h2{margin:0;font-size:26px}.topbar p{margin:4px 0 0;color:var(--muted)}button{font-family:inherit}.primary,.secondary{border:0;border-radius:12px;padding:12px 16px;font-weight:700;cursor:pointer}.primary{background:var(--primary);color:#fff}.primary:hover{background:var(--primary-2)}.secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.small{padding:9px 12px;font-size:13px}.topbar-actions{display:flex;gap:10px}.view{display:none}.view.active{display:block}.filters{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:12px;margin-bottom:18px}.filters input,.filters select,input,select,textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text)}textarea{min-height:105px;resize:vertical}.cards-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:14px;margin-bottom:18px}.metric-card{background:var(--panel);padding:18px;border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--border)}.metric-card span{color:var(--muted);font-size:13px}.metric-card strong{display:block;font-size:30px;margin-top:8px}.metric-card.warning strong{color:var(--warn)}.metric-card.danger strong{color:var(--danger)}.metric-card.dark strong{color:var(--dark)}.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.panel,.form-card{background:var(--panel);border-radius:20px;padding:18px;box-shadow:var(--shadow);border:1px solid var(--border)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.panel h3,.form-card h3{margin:0 0 12px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px;border-bottom:1px solid var(--border);text-align:left;font-size:14px;vertical-align:top}th{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}.tag{display:inline-flex;padding:5px 8px;border-radius:999px;background:#eef8f2;color:var(--primary);font-size:12px;font-weight:800}.tag.warn{background:#fff7ed;color:#c2410c}.tag.danger{background:#fef2f2;color:#b91c1c}.form-card{max-width:980px}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}label{font-size:13px;font-weight:700;color:#374151;display:grid;gap:7px;margin-bottom:12px}.form-actions{display:flex;align-items:center;gap:12px;margin:6px 0 14px}.sync-list{display:grid;gap:10px;margin-top:12px}.sync-item{padding:12px;border:1px solid var(--border);border-radius:12px;background:#f9fafb}.toast{position:fixed;right:22px;bottom:22px;background:#111827;color:#fff;padding:14px 16px;border-radius:14px;box-shadow:var(--shadow);display:none;max-width:360px}.toast.show{display:block}@media(max-width:1050px){.app-shell{display:block}.sidebar{position:relative;width:auto;height:auto}.cards-grid{grid-template-columns:repeat(2,1fr)}.panel-grid,.filters,.form-grid{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column}.topbar-actions{width:100%;flex-wrap:wrap}.primary,.secondary{width:auto}}@media(max-width:560px){.main{padding:14px}.cards-grid{grid-template-columns:1fr}.sidebar{padding:16px}.topbar h2{font-size:22px}}
.hidden{display:none!important}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eef6ff,#f8fafc);padding:24px}.login-card{width:min(430px,100%);background:#fff;border-radius:24px;padding:28px;box-shadow:0 20px 60px rgba(15,23,42,.16);display:grid;gap:16px}.login-brand{margin-bottom:8px}.login-card label{font-weight:700;color:#0f172a}.login-card input{margin-top:6px}.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.small{font-size:.85rem;padding:8px 12px}.table-action{border:0;border-radius:10px;padding:7px 10px;background:#e8f1ff;color:#0b57d0;font-weight:700;cursor:pointer}input[readonly]{background:#f1f5f9;color:#475569}.sidebar-footer strong{display:block;color:#fff;margin:4px 0}.sidebar-footer small{display:block}
.clickable{cursor:pointer;transition:.15s transform,.15s box-shadow}.clickable:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(15,23,42,.12)}.link-button{border:0;background:transparent;color:#0b57d0;font-weight:800;cursor:pointer;padding:0;text-align:left}.link-button:hover{text-decoration:underline}.check-inline{display:flex!important;align-items:center;gap:10px;grid-template-columns:auto 1fr!important;font-size:14px}.check-inline input{width:auto;margin:0}.detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.detail-item{background:#f8fafc;border:1px solid var(--border);border-radius:14px;padding:12px}.detail-item span{display:block;color:var(--muted);font-size:12px}.detail-item strong{display:block;margin-top:5px}.detail-panels{margin-top:18px}.metric-card.clickable span::after{content:'  • clique para ver';font-size:11px;color:#94a3b8}@media(max-width:900px){.detail-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.detail-grid{grid-template-columns:1fr}}


/* V7 - Menu lateral mobile como drawer */
.drawer-overlay,.mobile-menu-btn,.topbar-menu{display:none}
.topbar-title{display:flex;align-items:center;gap:12px}
.topbar-menu{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:12px;width:44px;height:44px;font-size:22px;font-weight:800;cursor:pointer;flex:0 0 auto}
@media(max-width:1050px){
  .app-shell{display:block;min-height:100vh}
  .main{padding-top:20px}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:min(82vw,330px);height:100vh;z-index:50;transform:translateX(-105%);transition:transform .22s ease;overflow:auto;box-shadow:20px 0 60px rgba(15,23,42,.22)}
  .app-shell.menu-open .sidebar{transform:translateX(0)}
  .drawer-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:40}
  .app-shell.menu-open .drawer-overlay{display:block}
  .topbar-menu{display:inline-grid;place-items:center}
  .mobile-menu-btn{display:none}
  .topbar{position:sticky;top:0;z-index:30;background:rgba(244,246,248,.92);backdrop-filter:blur(10px);padding:12px 0;margin:0 0 18px}
  .nav-item{padding:14px 16px;font-size:16px}
  .sidebar-footer{padding-bottom:24px}
}
@media(max-width:560px){
  .main{padding:14px 14px 24px}
  .topbar h2{font-size:24px}
  .topbar p{font-size:14px}
  .topbar-actions .primary,.topbar-actions .secondary{flex:1;min-width:140px}
}

/* V8 - Ajustes mobile: painéis do dashboard do mesmo tamanho e tabelas compactas */
.metric-card{min-height:118px;display:flex;flex-direction:column;justify-content:center}
.panel-grid .panel{display:flex;flex-direction:column;min-height:360px}
.panel-grid .table-wrap{max-height:285px;overflow:auto}
#dashboardDetalhe .table-wrap{max-height:340px;overflow:auto}
@media(max-width:560px){
  .metric-card{min-height:116px}
  .panel-grid .panel{min-height:300px;max-height:300px;overflow:hidden}
  .panel-grid .panel-header{min-height:44px;margin-bottom:8px}
  .panel-grid .panel h3{font-size:16px;line-height:1.2;margin:0}
  .panel-grid .table-wrap{max-height:220px;overflow:auto}
  #dashboardDetalhe{max-height:360px;overflow:hidden}
  #dashboardDetalhe .table-wrap{max-height:270px;overflow:auto}
  th,td{padding:10px 8px;font-size:13px}
}

/* ============================================================
   MOBILE — Sidebar sempre scrollável, botão Sair sempre visível
   ============================================================ */
@media(max-width:1050px){
  /* Sidebar vira drawer scrollável */
  .sidebar{
    overflow-y:auto;
    padding-bottom:24px;
  }
  /* Botão sair não usa margin-top:auto no mobile — fica no fluxo normal */
  .sidebar-footer{
    margin-top:24px;
  }
  /* Botão sair grande e fácil de tocar */
  #btnSair{
    width:100%;
    padding:16px;
    font-size:16px;
  }
  /* Esconde itens pesados no mobile */
  #graficoVisitasDia,
  #graficoTiposAcao,
  #gestorFunil,
  #gestorTemperatura,
  #vendFunil,
  #vendTemperatura{
    display:none;
  }
  /* Esconde painéis de gráficos inteiros no mobile */
  .mobile-hide{ display:none!important; }

  /* Dashboard mobile — cards em 2 colunas */
  .cards-grid{ grid-template-columns:repeat(2,1fr); }

  /* Barra de meta mais compacta */
  #vendMetaBarra{ height:18px; }

  /* Tabelas mobile — fonte menor e padding menor */
  th,td{ padding:8px 6px; font-size:12px; }

  /* Botões de ação nas tabelas */
  .table-action{ padding:5px 8px; font-size:12px; }

  /* Navegação mobile — itens grandes para toque */
  .nav-item{ padding:16px 14px; font-size:16px; }

  /* Barra de busca ocupa tudo */
  #buscaClienteVisita{ font-size:16px; }
}

@media(max-width:560px){
  /* Cards em 2 colunas mesmo no menor */
  .cards-grid{ grid-template-columns:repeat(2,1fr); }

  /* Formulários em coluna única */
  .form-grid{ grid-template-columns:1fr!important; }

  /* Topbar compacta */
  .topbar{ padding:10px 0; margin-bottom:14px; }
  .topbar h2{ font-size:20px; }

  /* Painéis sem padding excessivo */
  .panel,.form-card{ padding:14px; border-radius:16px; }
}

/* ============================================================
   BARRA DE NAVEGAÇÃO RÁPIDA — só no mobile, grid 2x2
   ============================================================ */
.mobile-nav{ display:none; }

@media(max-width:1050px){
  .mobile-nav{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin:0 0 18px;
    padding:0;
    background:transparent;
    border:none;
  }
  .mobile-nav button{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:7px;
    padding:13px 10px;
    border-radius:50px;
    border:none;
    cursor:pointer;
    font-size:13px;
    font-weight:600;
    font-family:inherit;
    background:#fff;
    color:#333;
    box-shadow:0 1px 4px rgba(0,0,0,.10);
    transition:all .15s ease;
  }
  .mobile-nav button svg{ width:17px; height:17px; flex-shrink:0; }
  .mobile-nav button:active{ transform:scale(.97); }
  .mobile-nav .mobile-nav-primary{
    background:var(--primary);
    color:#fff;
    box-shadow:0 2px 8px rgba(23,107,69,.25);
  }
  .mobile-nav .mobile-nav-primary svg{ stroke:#fff; }
}

/* Esconde botão Lançar visita do topbar no mobile (já tem na barra) */
@media(max-width:1050px){
  .mobile-hide-btn{ display:none!important; }
  /* Remove padding-bottom extra — barra agora é no topo */
  .main{ padding-bottom:24px; }
}

/* Evita zoom automático no iOS ao focar em inputs */
@media(max-width:1050px){
  input, select, textarea {
    font-size: 16px !important;
  }
}

/* ── Alterações dashboard desktop ── */
.panel-ranking { min-height: 0 !important; height: 560px; }
.panel-ranking .table-wrap, .table-wrap-ranking { max-height: 490px !important; overflow: auto; }
.panel-chart { min-height: 0 !important; height: auto; }
.panel-chart canvas { max-height: 160px; }

/* Calendário dashboard e view agenda */
#calendarioAgenda, #calendarioAgendaView { font-family: inherit; }

/* Agenda view mobile */
@media(max-width:768px){
  #view-agenda .panel-header { flex-wrap: wrap; gap: 8px; }
  #view-agenda .panel-header h3 { width: 100%; }
  #view-agenda .panel-header > div { width: 100%; justify-content: space-between; }
}

/* Mobile: esconde colunas marcadas como mobile-hide em tabelas */
@media(max-width:768px){
  td.mobile-hide, th.mobile-hide { display: none !important; }
}

/* Cards comentários e tarefas — coluna única no mobile */
@media(max-width:768px){
  #gridComentariosTarefas {
    grid-template-columns: 1fr !important;
  }
  #cardComentariosVendedor,
  #cardTarefasVendedor {
    max-height: none !important;
    overflow: visible !important;
  }
}

/* Kanban */
#kanbanGestor, #kanbanVendedor {
  padding-bottom: 4px;
  align-items: stretch;
}
#kanbanGestor > div, #kanbanVendedor > div {
  transition: opacity .2s;
  display: flex;
  flex-direction: column;
}
/* Scroll interno nas colunas */
#kanbanGestor > div > div:last-child,
#kanbanVendedor > div > div:last-child {
  overflow-y: auto;
  flex: 1;
}

/* Agenda por vendedor — texto quebra dentro da célula */
.table-wrap-ranking td { word-break: break-word; }
