:root {
  --primary:       #1B4FD8;
  --primary-dark:  #1338A8;
  --primary-light: #EEF2FF;
  --accent:        #22C55E;
  --accent-dark:   #16A34A;
  --danger:        #EF4444;
  --warning:       #F59E0B;
  --info:          #06B6D4;
  --sidebar-bg:    #0F1C35;
  --sidebar-w:     258px;
  --bg:            #F1F4FA;
  --surface:       #FFFFFF;
  --border:        #E2E8F0;
  --text:          #0F172A;
  --text2:         #475569;
  --text3:         #94A3B8;
  --radius:        12px;
  --shadow:        0 2px 16px rgba(15,23,42,.08);
  --shadow-lg:     0 8px 32px rgba(15,23,42,.12);
}
*,*::before,*::after{box-sizing:border-box;}
body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--text);margin:0;}

/* Layout */
.app-wrapper{display:flex;min-height:100vh;}
.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;}
.page-content{padding:28px;flex:1;}

/* Sidebar */
.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:200;transition:transform .3s;overflow:hidden;}
.sidebar-brand{padding:20px 18px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.07);}
.brand-icon{width:40px;height:40px;border-radius:10px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;}
.brand-text strong{display:block;color:#fff;font-size:17px;font-weight:800;}
.brand-text span{color:rgba(255,255,255,.35);font-size:10px;letter-spacing:2px;text-transform:uppercase;}
.sidebar-tenant{margin:10px 14px;padding:8px 12px;background:rgba(27,79,216,.2);border:1px solid rgba(27,79,216,.35);border-radius:8px;display:flex;align-items:center;gap:8px;}
.tenant-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;flex-shrink:0;}
.tenant-name{color:rgba(255,255,255,.8);font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.sidebar-nav{flex:1;overflow-y:auto;padding:8px 10px;}
.sidebar-nav::-webkit-scrollbar{width:3px;}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px;}
.nav-section{color:rgba(255,255,255,.2);font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:14px 10px 5px;}
.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;color:rgba(255,255,255,.45);font-size:13px;font-weight:500;text-decoration:none;margin-bottom:2px;transition:all .18s;border:1px solid transparent;}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.07);}
.nav-link.active{color:#fff;background:rgba(27,79,216,.4);border-color:rgba(27,79,216,.5);}
.nav-link i{font-size:16px;width:20px;text-align:center;}
.sidebar-footer{padding:12px 14px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px;}
.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.user-details{flex:1;min-width:0;}
.user-details strong{display:block;color:#fff;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.user-details small{color:rgba(255,255,255,.35);font-size:10px;}
.logout-btn{color:rgba(255,255,255,.3);font-size:18px;text-decoration:none;transition:color .18s;}
.logout-btn:hover{color:var(--danger);}

/* Topbar */
.topbar{height:60px;background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.05);}
.topbar-title{font-size:18px;font-weight:700;}
.topbar-title small{font-weight:400;font-size:13px;color:var(--text3);margin-left:8px;}

/* KPI Grid */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;margin-bottom:24px;}
.kpi-card{background:var(--surface);border-radius:var(--radius);padding:20px;border:1px solid var(--border);box-shadow:var(--shadow);border-top:3px solid var(--kpi-color,var(--primary));transition:transform .2s,box-shadow .2s;}
.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.kpi-icon{font-size:26px;margin-bottom:12px;}
.kpi-value{font-size:28px;font-weight:800;line-height:1;}
.kpi-label{color:var(--text2);font-size:12px;font-weight:500;margin-top:4px;}
.kpi-delta{font-size:11px;font-weight:600;margin-top:6px;}
.kpi-delta.up{color:var(--accent);}
.kpi-delta.down{color:var(--danger);}

/* Chart Cards */
.chart-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;}
.chart-header{padding:16px 20px 0;}
.chart-title{font-size:14px;font-weight:700;}
.chart-sub{font-size:11px;color:var(--text3);margin-top:2px;}
.chart-body{padding:14px 20px 20px;}
.chart-body canvas{max-height:220px;}

/* Tables */
.card-table{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;margin-bottom:20px;}
.card-table-header{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);}
.card-table-title{font-size:14px;font-weight:700;}
.table{margin:0;}
.table thead th{padding:10px 14px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;background:#F8FAFC;border-bottom:1px solid var(--border);}
.table tbody tr{transition:background .15s;}
.table tbody tr:hover{background:#F8FAFC;}
.table tbody td{padding:11px 14px;font-size:13px;vertical-align:middle;border-bottom:1px solid #F1F4FA;}

/* Badges */
.badge-success{background:rgba(34,197,94,.12);color:#15803D;}
.badge-warning{background:rgba(245,158,11,.12);color:#B45309;}
.badge-danger{background:rgba(239,68,68,.12);color:#B91C1C;}
.badge-info{background:rgba(6,182,212,.12);color:#0E7490;}
.badge-primary{background:rgba(27,79,216,.12);color:#1338A8;}

/* Forms */
.form-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:28px;margin-bottom:20px;}
.form-label{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;}
.form-control,.form-select{border:1.5px solid var(--border);border-radius:8px;font-family:'Poppins',sans-serif;font-size:13px;padding:9px 12px;transition:border-color .18s,box-shadow .18s;}
.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,79,216,.12);outline:none;}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;font-family:'Poppins',sans-serif;font-weight:600;}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);}
.btn-success{background:var(--accent);border-color:var(--accent);color:#fff;font-family:'Poppins',sans-serif;font-weight:600;}
.btn-outline-primary{font-family:'Poppins',sans-serif;}
.btn-outline-secondary{font-family:'Poppins',sans-serif;}

/* WhatsApp */
.btn-whatsapp{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#25D366;color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:600;text-decoration:none;transition:background .18s;}
.btn-whatsapp:hover{background:#1DA851;color:#fff;}

/* Sentiment */
.sentiment-bar{height:6px;border-radius:3px;background:#E2E8F0;overflow:hidden;margin-bottom:2px;}
.sentiment-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#EF4444,#F59E0B 50%,#22C55E);transition:width .4s;}

/* Auth */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0A1628 0%,#1B3060 100%);padding:20px;}
.auth-page h1,.auth-page h2,.auth-page h3,.auth-page h4,.auth-page h5,.auth-page h6{color:#f1f5f9;}
.auth-page p,.auth-page small,.auth-page label,.auth-page .text-muted,.auth-page .form-label,.auth-page .step-header{color:#cbd5e1 !important;}
.auth-page > div > p { color:#cbd5e1 !important; }
.auth-page a{color:#93c5fd;}
.auth-page a:hover{color:#bfdbfe;}
.auth-card{background:#fff;border-radius:18px;padding:40px;width:440px;max-width:100%;box-shadow:0 24px 64px rgba(0,0,0,.25);}
.auth-card p,.auth-card small,.auth-card label,.auth-card .text-muted,.auth-card .form-label{color:var(--text2) !important;}
.auth-card a{color:var(--primary);}
.auth-logo{text-align:center;margin-bottom:28px;}
.auth-logo .logo-icon{width:56px;height:56px;border-radius:14px;background:var(--primary);color:#fff;font-size:26px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:10px;}
.auth-logo h1{font-size:22px;font-weight:800;margin:0;color:#0f172a;}
.auth-logo p{color:var(--text3);font-size:13px;}

/* ═══════════════════════════════════════════════════
   MOBILE — SIDEBAR TOGGLE + OVERLAY
═══════════════════════════════════════════════════ */
.sidebar-toggle {
  position: fixed;
  top: 12px; left: 12px;
  z-index: 9999;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 12px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 2px 12px rgba(27,79,216,.4);
  transition: background .15s, transform .1s;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.sidebar-toggle:hover  { background: var(--primary-dark); }
.sidebar-toggle:active { transform: scale(.93); }

/* Overlay que escurece o conteúdo quando sidebar está aberta */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 199;
  backdrop-filter: blur(2px);
}
.sidebar-overlay.active { display: block; }

/* ═══════════════════════════════════════════════════
   RESPONSIVE — 768px e abaixo
═══════════════════════════════════════════════════ */
@media (max-width: 991px) {
  /* Sidebar desliza para fora */
  .sidebar { transform: translateX(-100%); box-shadow: none; }
  .sidebar.open {
    transform: none;
    box-shadow: 4px 0 24px rgba(0,0,0,.3);
  }

  /* Conteúdo principal ocupa tela toda */
  .main-content { margin-left: 0; }

  /* Topbar com espaço para o botão hambúrguer */
  .topbar {
    padding: 0 16px 0 60px;
    height: 54px;
    flex-wrap: wrap;
    gap: 6px;
  }
  .topbar-title { font-size: 15px; }
  .topbar-title small { display: none; }

  /* Page content compacto */
  .page-content { padding: 14px 12px; }

  /* KPI grid 2 colunas */
  .kpi-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .kpi-card { padding: 14px; }
  .kpi-value { font-size: 22px; }
  .kpi-icon { font-size: 20px; margin-bottom: 8px; }

  /* Charts menores */
  .chart-body canvas { max-height: 160px !important; }
  .chart-card { margin-bottom: 14px; }

  /* Tabelas com scroll horizontal */
  .card-table { overflow-x: auto; }
  .table { min-width: 600px; }
  .card-table-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .card-table-header form { width: 100%; flex-wrap: wrap; }

  /* Formulários empilham */
  .form-card { padding: 18px 14px; }
  .row.g-3 > [class*="col-md"] { flex: 0 0 100%; max-width: 100%; }

  /* Botões full width em mobile quando em stack */
  .d-flex.gap-2.flex-wrap .btn { flex: 1 1 auto; }

  /* Ocultar colunas menos importantes em tabelas */
  .table .hide-mobile { display: none; }

  /* Page header compacto */
  .page-header { flex-direction: column; align-items: flex-start !important; gap: 10px; }
  .page-header .ms-auto { margin-left: 0 !important; }
}

/* ═══════════════════════════════════════════════════
   RESPONSIVE — 576px e abaixo (phones pequenos)
═══════════════════════════════════════════════════ */
@media (max-width: 576px) {
  .kpi-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .kpi-card { padding: 12px; }
  .kpi-value { font-size: 20px; }

  /* Row cols em 1 coluna */
  .row > .col-6 { flex: 0 0 50%; max-width: 50%; }
  .row > .col-12, .row > .col { flex: 0 0 100%; max-width: 100%; }

  /* Topbar ainda mais compacto */
  .topbar { height: auto; min-height: 54px; padding: 8px 12px 8px 58px; }

  /* Esconder badges/textos secundários */
  .topbar .badge { display: none; }
  .topbar .text-muted.small { display: none; }

  /* Sidebar um pouco mais estreita */
  .sidebar { width: 240px; }
}

/* ═══════════════════════════════════════════════════
   UTILITÁRIOS MOBILE
═══════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .d-mobile-none { display: none !important; }
  .w-mobile-100  { width: 100% !important; }
  .text-mobile-center { text-align: center !important; }
  /* Scroll horizontal em divs de filtro */
  .filter-scroll-mobile { overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; }
}

/* ═══════════════════════════════════════════════════
   GLOBAL MOBILE FIXES — tabelas e formulários
═══════════════════════════════════════════════════ */

/* Todas as tabelas dentro do conteúdo ganham scroll horizontal */
.page-content .table:not(.table-no-scroll) {
  display: block;
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
@media (min-width: 769px) {
  .page-content .table:not(.table-no-scroll) {
    display: table;
    overflow-x: visible;
  }
}

/* Filtros em linha viram coluna em mobile */
@media (max-width: 768px) {
  .card-table-header { padding: 12px 14px; }
  .card-table-header .d-flex.gap-2,
  .card-table-header form.d-flex {
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100%;
  }
  .card-table-header .form-select,
  .card-table-header .form-control,
  .card-table-header input[type="date"],
  .card-table-header input[type="text"] {
    width: 100% !important;
    min-width: unset !important;
  }
  .card-table-header .btn { width: 100%; justify-content: center; }

  /* Formulários de busca em topbar */
  .topbar form.d-flex { flex-wrap: wrap; }

  /* Ajusta grid de colunas para mobile */
  .row > .col-lg-4,
  .row > .col-lg-6,
  .row > .col-lg-8,
  .row > .col-md-4,
  .row > .col-md-6,
  .row > .col-md-8 {
    /* Bootstrap já cuida, mas garante que as classes customizadas também */
  }

  /* Form-cards com duas colunas viram uma */
  .form-card .row .col-md-6 { flex: 0 0 100%; max-width: 100%; }
  .form-card .row .col-md-4 { flex: 0 0 100%; max-width: 100%; }
  .form-card .row .col-md-3 { flex: 0 0 50%; max-width: 50%; }

  /* Inputs side-by-side na topbar */
  .topbar input[type="date"] { width: 100% !important; min-width: unset !important; }
  .topbar select.form-select  { width: 100% !important; min-width: unset !important; }

  /* Botões de ação em tabela - icones menores */
  .table .btn-sm { padding: 3px 7px; font-size: 11px; }

  /* Page header botões em linha */
  .page-header .btn { font-size: 12px; padding: 5px 10px; }

  /* KPI cards col-6 padrão */
  .row .col-6.col-md-3 { flex: 0 0 50%; max-width: 50%; }
  .row .col-6.col-md-4 { flex: 0 0 50%; max-width: 50%; }

  /* Ocultar colunas de baixa prioridade em tabelas */
  .table th.d-none-mobile,
  .table td.d-none-mobile { display: none !important; }

  /* Charts responsivos */
  canvas { max-width: 100% !important; }

  /* Evitar overflow horizontal global */
  .page-content { overflow-x: hidden; }
  .main-content  { overflow-x: hidden; }
}

@media (max-width: 480px) {
  /* Botões de ação - apenas ícone */
  .table .btn-sm span.btn-label { display: none; }
  .table .btn-sm i { margin: 0 !important; }

  /* KPI em 1 coluna para telas muito pequenas quando tiver 4+ */
  .row.kpi-4col > .col-6 { flex: 0 0 50%; max-width: 50%; }

  /* Fonte base menor */
  body { font-size: 13px; }
  .table tbody td { font-size: 12px; padding: 8px 10px; }
  .table thead th { font-size: 10px; padding: 8px 10px; }
}

/* ═══════════════════════════════════════════════════
   RESPONSIVE EXTRAS — ajustes complementares
═══════════════════════════════════════════════════ */

/* Topbar: itens secundários somem primeiro em telas pequenas */
@media (max-width: 900px) {
  .topbar { padding: 0 16px 0 62px; gap: 8px; }
  .topbar .text-muted.small { display: none; }
}
@media (max-width: 768px) {
  /* Topbar: mostrar apenas título + ações essenciais */
  .topbar { padding: 0 12px 0 58px; height: auto; min-height: 54px; flex-wrap: wrap; gap: 4px; }
  .topbar-title { font-size: 14px; }
  .topbar-title small { display: none; }
  .topbar .badge { font-size: 10px; padding: 3px 8px; }
  .topbar .btn-sm { font-size: 11px; padding: 4px 8px; }

  /* Selects e inputs em filtros: sem min-width forçado */
  .card-table-header select,
  .card-table-header input,
  form select.form-select-sm,
  form input.form-control-sm {
    min-width: unset !important;
    width: 100% !important;
  }

  /* Filtros da topbar em coluna */
  .topbar form { flex-wrap: wrap; gap: 6px; }
  .topbar form select,
  .topbar form input { min-width: unset !important; width: 100% !important; }

  /* Botões de atalho de período (Hoje, 7 dias, Mês) em linha scrollável */
  .btn-group-periodo { display: flex; gap: 4px; overflow-x: auto; padding-bottom: 2px; -webkit-overflow-scrolling: touch; }
  .btn-group-periodo .btn { white-space: nowrap; flex-shrink: 0; }

  /* Page-content em telas pequenas */
  .page-content { padding: 12px 10px 24px; }

  /* Charts: altura máxima menor */
  .chart-body canvas { max-height: 140px !important; }

  /* Colunas de tabela: forçar scroll horizontal */
  .card-table .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* Formulários de detail/form: campos full width */
  .form-card .row > [class*="col-"] { flex: 0 0 100% !important; max-width: 100% !important; }
  .form-card .row > .col-md-6,
  .form-card .row > .col-lg-6,
  .form-card .row > .col-md-4 { flex: 0 0 100% !important; max-width: 100% !important; }

  /* Botões de ação inline: empilha */
  .page-header .d-flex.gap-2 { flex-wrap: wrap; }
  .page-header .d-flex.gap-2 .btn { flex: 1 1 auto; text-align: center; justify-content: center; }

  /* KPI cards: 2 colunas */
  .row > .col-6.col-md-3,
  .row > .col-6.col-md-4 { flex: 0 0 50% !important; max-width: 50% !important; }

  /* Cards internos com scroll horizontal */
  .card-table-header .d-flex { flex-wrap: wrap !important; }

  /* Inputs de data lado a lado: colapsar */
  .topbar input[type="date"],
  .card-table-header input[type="date"] { width: 100% !important; min-width: unset !important; }

  /* Equipe index: abas em scroll horizontal */
  .eq-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; display: flex; }
  .eq-tab  { flex-shrink: 0; }

  /* Ocultar colunas de baixa prioridade em tabelas mobile */
  .table .col-mobile-hide,
  .table th.col-mobile-hide,
  .table td.col-mobile-hide { display: none !important; }

  /* Botão de ação em tabela: só ícone */
  .table .btn-action-label { display: none; }
}

@media (max-width: 480px) {
  /* KPI em tela muito pequena: 1 coluna se tiver só 2 */
  .row.g-3.kpi-2col > .col-6 { flex: 0 0 100% !important; max-width: 100% !important; }

  /* Fonte menor em tabelas */
  .table tbody td { font-size: 11px; padding: 7px 8px; }
  .table thead th { font-size: 10px; padding: 7px 8px; }

  /* Padding mínimo */
  .page-content { padding: 8px 8px 20px; }
  .form-card { padding: 14px 12px; }
  .card-table-header { padding: 10px 12px; }
}

/* ── Equipe: fix abas mobile ── */
@media (max-width: 768px) {
  .eq-tabs-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
  }
  .eq-tabs {
    display: inline-flex;
    min-width: max-content;
  }
}
