/* ================================================================
   Maestro · Mobile Layer (v1)
   2026-05-05 — Camada mobile global, ativa apenas em <=900px.
   Não substitui desktop; apenas sobrescreve onde mobile precisa.
   Usa tokens existentes (var(--bg), var(--surface), etc.)
   pra herdar Focus/Command + light/dark automaticamente.
   ================================================================ */

/* ---------- Mobile-only utility (visible apenas em <=900px) ---------- */
.cmd-mobile-only, .focus-mobile-only { display: none !important; }
@media (max-width: 900px) {
  .cmd-mobile-only, .focus-mobile-only { display: inline-flex !important; align-items: center; justify-content: center; }
}

@media (max-width: 900px) {

/* ---------- Base mobile reset ---------- */
html, body {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  overscroll-behavior-y: contain;
}
body {
  font-size: 15px;
  line-height: 1.5;
}
button, a, [role="button"], .nav-item, .m-bn-item {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
/* Touch targets — Apple HIG mínimo 44px, Material 48dp.
   Aplica defaults pro app inteiro; rules específicas (.btn-sm em listas etc.) sobrescrevem. */
.btn-icon {
  min-width: 38px; min-height: 38px;
  padding: 8px !important;
  border-radius: 8px;
}
.btn-icon svg { width: 18px; height: 18px; }
.btn-sm {
  min-height: 36px;
  padding: 8px 12px !important;
  font-size: 13px !important;
}
.modal-close, .modal-header > button:last-child {
  min-width: 38px !important; min-height: 38px !important;
  padding: 8px !important;
  border-radius: 8px;
}
.modal-close:active { background: var(--surface2); }
/* Chips e pills clicáveis */
.chip, .pill, .role-chip, .badge {
  min-height: 26px;
}
/* Avatar clicável (em listas de usuário) */
.avatar.clickable, [data-clickable-avatar] { cursor: pointer; }
/* iOS: inputs <16px causam zoom on focus — força >=16px */
input, select, textarea, .form-control {
  font-size: 16px !important;
}
.form-control { padding: 12px 14px !important; }
/* desabilita hover effects em touch devices */
@media (hover: none) {
  .nav-item:hover, .btn:hover, .card:hover, .cmd-row:hover { background: inherit; }
}

/* ---------- Topbar mobile-otimizada ---------- */
.topbar, .cmd-topbar {
  height: 56px !important;
  padding: 0 16px !important;
  position: sticky; top: 0;
  background: var(--bg2);
  backdrop-filter: saturate(1.2) blur(12px);
  -webkit-backdrop-filter: saturate(1.2) blur(12px);
  z-index: 240;
  padding-top: env(safe-area-inset-top, 0px) !important;
  height: calc(56px + env(safe-area-inset-top, 0px)) !important;
  border-bottom: 1px solid var(--border);
}
.topbar-search, .cmd-search { display: none !important; }
/* Remove hambúrguer em mobile — bottom nav "Mais" cobre */
#sidebarToggle, #cmdSidebarToggle { display: none !important; }
/* Topbar title vira título contextual (empresa / saudação) */
.topbar-title, .cmd-topbar-title {
  font-size: 16.5px !important;
  font-weight: 600 !important;
  letter-spacing: -.3px;
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text);
  padding-left: 2px;
}
.topbar-title .m-greet,
.cmd-topbar-title .m-greet {
  display: block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 1px;
}
.topbar .icon-btn, .cmd-topbar .icon-btn, .topbar .cmd-btn, .cmd-topbar .cmd-btn,
.topbar .cmd-icon-btn, .cmd-topbar .cmd-icon-btn {
  min-width: 40px; min-height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
}

/* ---------- Esconder WhatsApp do menu em mobile ---------- */
.nav-item[href*="/whatsapp"],
.cmd-nav-item[href*="/whatsapp"],
.sidebar a[href$="/whatsapp"],
.cmd-sidebar a[href$="/whatsapp"] {
  display: none !important;
}

/* ---------- Sidebar como drawer (Focus + Command) ---------- */
.sidebar, .cmd-sidebar {
  width: min(320px, 86vw) !important;
  max-width: 320px !important;
  transform: translateX(-100%);
  transition: transform .28s cubic-bezier(.4,0,.2,1);
  z-index: 320 !important;
  box-shadow: none;
  height: 100dvh !important;
  min-height: 100dvh !important;
  padding-top: env(safe-area-inset-top, 0px);
  padding-bottom: env(safe-area-inset-bottom, 0px);
  overscroll-behavior: contain;
}
.sidebar.open, .cmd-sidebar.open {
  transform: translateX(0);
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
}
.sidebar-overlay, #cmdSidebarOverlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 319;
  opacity: 0; visibility: hidden;
  transition: opacity .25s ease, visibility 0s linear .25s;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.sidebar-overlay.show, #cmdSidebarOverlay.show {
  opacity: 1; visibility: visible;
  transition: opacity .25s ease;
}
.main-wrap, .cmd-main-wrap { margin-left: 0 !important; }
/* botões de colapsar/expandir não fazem sentido em mobile */
.sidebar-collapse-btn, .sidebar-expand-btn,
.cmd-sidebar-pin, .cmd-collapse-btn { display: none !important; }
/* nav items maiores pra dedo */
.nav-item, .cmd-nav-item {
  min-height: 48px !important;
  padding: 12px 14px !important;
  font-size: 14.5px !important;
  border-radius: 10px !important;
}
.cmd-nav-item .cmd-nav-tooltip { display: none !important; }
.cmd-nav-item .cmd-nav-label { display: inline !important; }
/* tooltip do hover desktop não faz sentido em touch */
.cmd-nav-item:hover .cmd-nav-tooltip { display: none !important; }

/* ---------- Bottom Navigation (tab bar) ---------- */
.m-bn {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 250;
  display: flex;
  background: var(--bg2);
  backdrop-filter: saturate(1.2) blur(20px);
  -webkit-backdrop-filter: saturate(1.2) blur(20px);
  border-top: 1px solid var(--border);
  padding: 6px 4px calc(6px + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -1px 0 var(--border);
}
.m-bn-item {
  flex: 1;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 3px;
  padding: 6px 2px;
  min-height: 52px;
  color: var(--text2);
  text-decoration: none;
  border-radius: 10px;
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: -.1px;
  background: transparent;
  border: 0;
  position: relative;
  transition: color .18s ease, transform .12s ease;
}
.m-bn-item svg { width: 22px; height: 22px; stroke-width: 1.75; }
.m-bn-item.active { color: var(--text); font-weight: 600; }
.m-bn-item.active svg { stroke-width: 2; }
.m-bn-item:active { transform: scale(.94); }
/* indicador ativo: pequena pill acima do ícone (estilo Material 3 / iOS) */
.m-bn-item::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  width: 28px; height: 3px;
  background: var(--text);
  border-radius: 0 0 4px 4px;
  transform: translateX(-50%) scaleX(0);
  transform-origin: center;
  transition: transform .28s cubic-bezier(.4,0,.2,1);
  opacity: .9;
}
.m-bn-item.active::before { transform: translateX(-50%) scaleX(1); }
/* destaque sutil no fundo do ícone ativo */
.m-bn-item.active svg {
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.06));
}
/* item "criar" central tem destaque permanente */
/* Bloqueia menu de contexto nativo (long-press) no botão Criar e no bottom-nav inteiro */
.m-bn,
.m-bn-item {
  -webkit-touch-callout: none !important;
  -webkit-user-select: none;
  user-select: none;
}
.m-bn-item[data-mbn-action="create"] {
  position: relative;
}
.m-bn-item[data-mbn-action="create"] svg {
  background: var(--primary);
  color: var(--primary-fg);
  stroke: var(--primary-fg);
  border-radius: 14px;
  padding: 5px;
  width: 32px; height: 32px;
  margin-bottom: 1px;
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
  transition: transform .14s cubic-bezier(.4,0,.2,1);
}
.m-bn-item[data-mbn-action="create"]:active svg { transform: scale(.92); }
.m-bn-item[data-mbn-action="create"]::before { display: none; }
.m-bn-item[data-mbn-action="create"] span { font-weight: 600; }
.m-bn-badge {
  position: absolute;
  top: 2px; right: calc(50% - 18px);
  min-width: 16px; height: 16px;
  padding: 0 4px;
  background: var(--red, #DC2626);
  color: #fff;
  font-size: 9.5px; font-weight: 700;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  line-height: 1;
}
/* esconde bottom nav em telas auth/landing/embed */
body.no-bottom-nav .m-bn,
body.is-auth .m-bn,
body.is-landing .m-bn,
body.is-print .m-bn { display: none !important; }
/* dá espaço pro conteúdo não ficar atrás da bottom nav */
.main-wrap, .cmd-main-wrap, body.has-mbn .main-wrap, body.has-mbn .cmd-main-wrap {
  padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px));
}
.page, .cmd-page {
  padding: 14px 14px calc(80px + env(safe-area-inset-bottom, 0px)) !important;
}

/* ---------- FAB (Floating Action Button) ---------- */
.m-fab {
  position: fixed;
  right: 16px;
  bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  z-index: 260;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--primary);
  color: var(--primary-fg);
  border: 0;
  box-shadow: 0 8px 24px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.08);
  display: flex; align-items: center; justify-content: center;
  transition: transform .14s cubic-bezier(.4,0,.2,1), box-shadow .14s ease;
  -webkit-tap-highlight-color: transparent;
}
.m-fab svg { width: 24px; height: 24px; stroke-width: 2.25; }
.m-fab:active { transform: scale(.92); box-shadow: 0 4px 12px rgba(0,0,0,.15); }
body.no-fab .m-fab { display: none !important; }
/* esconde quando algum modal/drawer está aberto */
body.modal-open .m-fab, body.drawer-open .m-fab { display: none !important; }

/* ---------- "Mais" → Bottom Sheet nativo (substitui drawer lateral) ---------- */
.m-more-sheet {
  position: fixed; inset: 0;
  z-index: 380;
  pointer-events: none;
  visibility: hidden;
}
.m-more-sheet.open { pointer-events: auto; visibility: visible; }
.m-more-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity .25s cubic-bezier(.4,0,.2,1);
}
.m-more-sheet.open .m-more-overlay { opacity: 1; }
.m-more-panel {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  background: var(--bg2, var(--surface));
  border-radius: 20px 20px 0 0;
  max-height: 85dvh;
  display: flex; flex-direction: column;
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.32,.72,0,1);
  box-shadow: 0 -8px 32px rgba(0,0,0,.18);
  padding-bottom: env(safe-area-inset-bottom, 0px);
  overscroll-behavior: contain;
}
.m-more-sheet.open .m-more-panel { transform: translateY(0); }
.m-more-handle {
  width: 38px; height: 4px;
  background: var(--border-strong, #D4D4D4);
  border-radius: 999px;
  margin: 8px auto 4px;
  flex-shrink: 0;
  opacity: .8;
}
.m-more-scroll {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 14px 18px;
}

/* user card (header do sheet) */
.m-more-user {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 14px;
  margin: 4px 0 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  text-decoration: none;
  color: var(--text);
  -webkit-tap-highlight-color: transparent;
  transition: background .12s ease;
}
.m-more-user:active { background: var(--surface2); }
.m-more-user-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--primary);
  color: var(--primary-fg);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 16px;
  flex-shrink: 0;
  overflow: hidden;
}
.m-more-user-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.m-more-user-body { flex: 1; min-width: 0; }
.m-more-user-name {
  font-size: 15.5px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.m-more-user-role {
  font-size: 12.5px; color: var(--text2);
  text-transform: capitalize;
  margin-top: 2px;
}
.m-more-user svg { color: var(--text3); flex-shrink: 0; }

/* workspace switcher row */
.m-more-ws {
  display: flex; align-items: center; gap: 12px;
  width: 100%;
  padding: 12px 14px;
  margin: 0 0 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  cursor: pointer;
  font-family: inherit;
  color: var(--text);
  text-align: left;
  -webkit-tap-highlight-color: transparent;
  transition: background .12s ease;
}
.m-more-ws:active { background: var(--surface2); }
.m-more-ws-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--blue-soft, var(--surface2));
  color: var(--blue-fg, var(--text2));
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.m-more-ws-body { flex: 1; min-width: 0; }
.m-more-ws-label {
  font-size: 11px; color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .6px;
  font-weight: 600;
}
.m-more-ws-name {
  font-size: 15px; font-weight: 600;
  margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.m-more-ws-chev { color: var(--text3); flex-shrink: 0; }

/* sections + lists */
.m-more-section-title {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .8px;
  font-weight: 600;
  color: var(--text3);
  padding: 14px 6px 6px;
}
.m-more-list {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 4px;
}
.m-more-list + .m-more-section-title { padding-top: 18px; }
.m-more-actions { margin-top: 14px; }
.m-more-item {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  text-decoration: none;
  color: var(--text);
  font-size: 15px; font-weight: 500;
  border: 0; background: transparent;
  width: 100%;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  -webkit-tap-highlight-color: transparent;
  transition: background .12s ease;
  position: relative;
}
.m-more-item:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 50px; right: 16px; bottom: 0;
  height: 1px;
  background: var(--hairline, var(--border));
}
.m-more-item:active { background: var(--surface2); }
.m-more-item.active {
  background: var(--surface2);
  color: var(--text);
  font-weight: 600;
}
.m-more-item-icon {
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text2);
  flex-shrink: 0;
}
.m-more-item-icon svg { width: 20px; height: 20px; stroke-width: 1.75; }
.m-more-item.active .m-more-item-icon { color: var(--text); }
.m-more-item-label { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.m-more-item-badge {
  background: var(--primary);
  color: var(--primary-fg);
  font-size: 11px; font-weight: 700;
  padding: 2px 8px;
  border-radius: 999px;
  min-width: 20px;
  text-align: center;
  line-height: 1.4;
}
.m-more-item-chev { color: var(--text3); flex-shrink: 0; }
.m-more-item-danger { color: #DC2626; }
.m-more-item-danger .m-more-item-icon { color: #DC2626; }

/* esconde bottom nav atrás do sheet aberto */
body.m-more-open .m-bn { opacity: .35; pointer-events: none; }

/* ---------- Bottom Sheets (modais em mobile) ---------- */
.modal-overlay {
  padding: 0 !important;
  align-items: flex-end !important;
  background: rgba(0,0,0,.5) !important;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 9000 !important;  /* acima da topbar (240) e tudo mais */
}
#wsCreateOverlay, #wsEditOverlay, #wsDeleteOverlay, #obOverlay {
  z-index: 9100 !important;
}
#taskDrawer { z-index: 9200 !important; }
.modal {
  width: 100% !important;
  max-width: 100% !important;
  max-height: 92dvh !important;
  margin: 0 !important;
  border-radius: 18px 18px 0 0 !important;
  padding-top: env(safe-area-inset-top, 0px) !important;
  padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  will-change: transform;
  transform: translateZ(0); /* força GPU layer; evita flicker durante slide-up */
  animation: none !important; /* só anima quando .show — define abaixo */
}
/* (regra de createTaskInner está mais abaixo na linha ~605 — não duplicar aqui) */
/* anima APENAS quando overlay ganha .show (evita flicker de layout antes do show) */
.modal-overlay.show .modal {
  animation: m-sheet-up .22s cubic-bezier(.32,.72,0,1) !important;
}
@keyframes m-sheet-up {
  from { transform: translateY(100%); opacity: .8; }
  to   { transform: translateY(0); opacity: 1; }
}
/* drag handle visual no topo do bottom sheet */
.modal::before {
  content: '';
  display: block;
  position: sticky; top: 8px; z-index: 1;
  width: 40px; height: 4px;
  margin: 8px auto 0;
  background: var(--border-strong, #D4D4D4);
  border-radius: 999px;
  opacity: .8;
}
.modal-header {
  position: sticky; top: 0; z-index: 2;
  background: var(--surface);
  padding: 18px 18px 14px !important;
  border-bottom: 1px solid var(--hairline, var(--border));
  display: flex; align-items: center; justify-content: space-between;
}
.modal-title { font-size: 16px !important; font-weight: 600 !important; }
.modal-close {
  min-width: 36px; min-height: 36px;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
}
.modal-body { padding: 16px 18px !important; }
.modal-footer {
  position: sticky; bottom: 0;
  background: var(--surface);
  padding: 14px 18px calc(14px + env(safe-area-inset-bottom, 0px)) !important;
  border-top: 1px solid var(--hairline, var(--border));
  display: flex; gap: 10px;
}
.modal-footer .btn, .modal-footer button {
  flex: 1;
  min-height: 48px;
  font-size: 15px;
  border-radius: 12px;
}

/* ---------- Modais inline-styled (wsCreate/wsEdit/wsDelete/obOverlay) viram bottom sheets ---------- */
#wsCreateOverlay, #wsEditOverlay, #wsDeleteOverlay, #obOverlay {
  align-items: flex-end !important;
  padding: 0 !important;
}
#wsCreateOverlay > div, #wsEditOverlay > div, #wsDeleteOverlay > div {
  width: 100% !important;
  max-width: 100% !important;
  border-radius: 18px 18px 0 0 !important;
  padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  animation: m-sheet-up .2s cubic-bezier(.32,.72,0,1) !important;
  max-height: 92dvh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
/* createTaskInner: layout coluna com header sticky topo + footer sticky bottom */
#createTaskInner {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow-x: hidden !important;  /* mata scroll lateral causado pelo margin -24 do footer */
}
/* Header — barra fixa no topo */
#createTaskInner > div:first-child {
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
  background: var(--surface) !important;
  padding: calc(14px + env(safe-area-inset-top, 0)) 18px 12px !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
  border-bottom: 1px solid var(--border) !important;
}
/* Body do modal scrollável */
#createTaskInner > div:nth-child(2) {
  padding: 16px 18px calc(16px + env(safe-area-inset-bottom, 0)) !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-x: hidden !important;
}
/* Footer dos botões (Cancelar / Criar): zera o margin negativo desktop e ancora no bottom */
#createTaskInner form > div:last-child[style*="position:sticky"][style*="bottom:0"] {
  margin: 0 -18px -16px !important;  /* compensa o padding 18px do body novo */
  padding: 14px 18px calc(14px + env(safe-area-inset-bottom, 0)) !important;
  background: var(--surface) !important;
  border-top: 1px solid var(--border) !important;
}
#createTaskInner .btn-primary, #createTaskInner .btn-ghost {
  flex: 1 !important;
  min-height: 48px !important;
  font-size: 15px !important;
  border-radius: 12px !important;
  justify-content: center !important;
}
/* botão X mais visível */
#createTaskInner .modal-close {
  width: 40px !important; height: 40px !important;
  background: var(--surface2);
  border-radius: 12px !important;
  flex-shrink: 0;
}
#createTaskInner .modal-close svg { width: 14px !important; height: 14px !important; }

#wsCreateOverlay > div::before,
#wsEditOverlay > div::before,
#wsDeleteOverlay > div::before {
  content: '';
  display: block;
  width: 40px; height: 4px;
  margin: 8px auto 0;
  background: var(--border-strong, #D4D4D4);
  border-radius: 999px;
  opacity: .8;
}
#obOverlay > div {
  width: 100% !important;
  max-width: 100% !important;
  border-radius: 18px 18px 0 0 !important;
  margin: 0 !important;
}
/* botões dentro desses modais maiores */
#wsCreateOverlay button, #wsEditOverlay button, #wsDeleteOverlay button,
#wsCreateOverlay input, #wsEditOverlay input, #wsDeleteOverlay input,
#wsCreateOverlay select, #wsEditOverlay select {
  font-size: 16px !important;
  padding: 13px 14px !important;
  min-height: 46px;
  border-radius: 10px !important;
}

/* ---------- TaskDrawer full-screen REDESENHADO pra mobile ---------- */
#taskDrawer {
  width: 100vw !important;
  max-width: 100vw !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  padding-top: env(safe-area-inset-top, 0px);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
#drawerOverlay { display: none !important; }

/* Header do drawer: vira full-width column com botões em linha SEPARADA do título */
#taskDrawer [style*="padding:20px 24px"][style*="display:flex"][style*="flex-start"] {
  flex-direction: column !important;
  align-items: stretch !important;
  padding: calc(14px + env(safe-area-inset-top, 0)) 16px 14px !important;
  padding-right: 64px !important; /* espaço pro X absoluto */
  gap: 14px !important;
  position: relative;
}

/* Esconde link "Abrir página completa" (ícone external-link) em mobile */
#taskDrawer a[title="Abrir página completa"],
#taskDrawer a.btn[href*="/tasks/"][class*="btn-ghost"] {
  display: none !important;
}

/* Botão X de fechar fixado no canto superior direito do drawer */
#taskDrawer .btn-icon {
  position: absolute !important;
  top: calc(12px + env(safe-area-inset-top, 0)) !important;
  right: 14px !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 12px !important;
  background: var(--surface2) !important;
  border: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 5 !important;
  cursor: pointer;
}
#taskDrawer .btn-icon svg { width: 16px !important; height: 16px !important; }
#taskDrawer .btn-icon:active { background: var(--border) !important; transform: scale(.94); }
/* Bloco do título (esquerdo) ocupa 100% */
#taskDrawer [style*="flex:1;min-width:0"]:first-child {
  width: 100% !important;
}
/* Bloco de ações (direito) — em mobile vira GRID 2 colunas (mais espaço pra cada botão) */
#taskDrawer [style*="display:flex;gap:6px;flex-shrink:0"] {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 8px !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  overflow: visible !important;
}
#taskDrawer [style*="display:flex;gap:6px;flex-shrink:0"] > .btn {
  width: 100% !important;
  margin: 0 !important;
  justify-content: center !important;
}

/* Botões maiores em geral, com padding generoso pra texto não vazar */
#taskDrawer .btn {
  font-size: 13.5px !important;
  padding: 10px 14px !important;
  min-height: 42px !important;
  border-radius: 10px !important;
  white-space: nowrap !important;
}
#taskDrawer .btn-sm {
  font-size: 13px !important;
  padding: 9px 12px !important;
  min-height: 40px !important;
  border-radius: 10px !important;
  white-space: nowrap !important;
}
#taskDrawer .btn svg { flex-shrink: 0; }

/* Grid 2 col (datas/categoria/etc) vira 1 col */
#taskDrawer [style*="grid-template-columns:1fr 1fr"] { grid-template-columns: 1fr !important; }

/* Padding generoso em todos os blocos com padding fixo desktop */
#taskDrawer [style*="padding:18px 24px"],
#taskDrawer [style*="padding:16px 24px"],
#taskDrawer [style*="padding:24px"],
#taskDrawer [style*="padding:20px"] {
  padding: 14px 16px !important;
}

/* DrawerInner ocupa toda a tela e tem espaço pro bottom-nav */
#taskDrawer #drawerInner {
  padding-bottom: calc(80px + env(safe-area-inset-bottom, 0px));
}

/* Status pill / título */
#taskDrawer .badge {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  padding: 6px 12px;
  border-radius: 999px;
}

/* Avoid overflow horizontal — só blocos/inputs, não SVG/path/circle/etc */
#taskDrawer div, #taskDrawer p, #taskDrawer section, #taskDrawer article,
#taskDrawer textarea, #taskDrawer input, #taskDrawer select, #taskDrawer label,
#taskDrawer button, #taskDrawer a, #taskDrawer ul, #taskDrawer li {
  max-width: 100% !important;
  box-sizing: border-box !important;
}
#taskDrawer img { max-width: 100%; height: auto; }

/* Texto dos comentários e descrição quebrar palavras longas */
#taskDrawer p, #taskDrawer span, #taskDrawer div {
  word-wrap: break-word;
  overflow-wrap: anywhere;
}

/* ---------- Notif drawer → bottom-sheet em mobile ---------- */
.notif-drawer {
  position: fixed !important;
  left: 0 !important; right: 0 !important;
  top: auto !important;
  bottom: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  height: auto !important;
  max-height: 85dvh !important;
  border-left: 0 !important;
  border-radius: 20px 20px 0 0 !important;
  transform: translateY(100%) !important;
  transition: transform .26s cubic-bezier(.32,.72,0,1) !important;
  box-shadow: 0 -8px 32px rgba(0,0,0,.18) !important;
  z-index: 9100 !important;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  display: flex !important;
  flex-direction: column;
}
.notif-drawer.open {
  transform: translateY(0) !important;
}
/* drag handle visual no topo */
.notif-drawer::before {
  content: '';
  display: block;
  width: 38px; height: 4px;
  margin: 8px auto 4px;
  background: var(--border-strong, #D4D4D4);
  border-radius: 999px;
  flex-shrink: 0;
  opacity: .8;
}
.notif-header {
  padding: 8px 18px 14px !important;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--bg2);
}
.notif-list {
  padding: 4px 0 calc(16px + env(safe-area-inset-bottom, 0px)) !important;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1;
}
#notifOverlay {
  background: rgba(0,0,0,.45) !important;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 9090 !important;
}

/* ---------- Quick Actions bottom-sheet (long-press no Criar) ---------- */
.m-quick-actions {
  position: fixed; inset: 0;
  z-index: 9200;
  pointer-events: none;
  visibility: hidden;
}
.m-quick-actions.open { pointer-events: auto; visibility: visible; }
.m-qa-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity .22s ease;
}
.m-quick-actions.open .m-qa-overlay { opacity: 1; }
.m-qa-panel {
  position: absolute; left: 0; right: 0; bottom: 0;
  background: var(--bg2);
  border-radius: 20px 20px 0 0;
  padding: 8px 14px calc(14px + env(safe-area-inset-bottom, 0px));
  transform: translateY(100%);
  transition: transform .28s cubic-bezier(.32,.72,0,1);
  box-shadow: 0 -8px 32px rgba(0,0,0,.18);
}
.m-quick-actions.open .m-qa-panel { transform: translateY(0); }
.m-qa-handle {
  width: 38px; height: 4px;
  margin: 6px auto 14px;
  background: var(--border-strong, #D4D4D4);
  border-radius: 999px;
  opacity: .8;
}
.m-qa-title {
  text-align: center;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .8px;
  font-weight: 600;
  color: var(--text3);
  margin-bottom: 12px;
}
.m-qa-list {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}
.m-qa-item {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  text-decoration: none;
  color: var(--text);
  font-size: 15px; font-weight: 500;
  border: 0; background: transparent;
  width: 100%;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  position: relative;
  transition: background .12s ease;
}
.m-qa-item:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 56px; right: 16px; bottom: 0;
  height: 1px;
  background: var(--hairline, var(--border));
}
.m-qa-item:active { background: var(--surface2); }
.m-qa-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.m-qa-icon svg { width: 18px; height: 18px; stroke-width: 2; }
.m-qa-icon.task    { background: var(--blue-soft);   color: var(--blue-fg); }
.m-qa-icon.reminder{ background: var(--yellow-soft); color: var(--yellow-fg); }
.m-qa-icon.meet    { background: var(--green-soft);  color: var(--green-fg); }
.m-qa-cancel {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  margin-top: 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  font-family: inherit;
}
.m-qa-cancel:active { background: var(--surface2); }
body.m-qa-open { overflow: hidden; }
body.m-qa-open .m-bn { opacity: .35; pointer-events: none; }

/* ---------- AI bubble repositionada ---------- */
.ai-bubble {
  bottom: calc(80px + env(safe-area-inset-bottom, 0px)) !important;
  right: 16px !important;
  z-index: 245;
}
.ai-chat {
  width: calc(100vw - 24px) !important;
  right: 12px !important; left: 12px !important;
  bottom: calc(150px + env(safe-area-inset-bottom, 0px)) !important;
  max-height: 65vh !important;
  border-radius: 16px !important;
}

/* ---------- Toast container ---------- */
.toast-container {
  left: 12px !important; right: 12px !important;
  transform: none !important;
  width: auto !important;
  bottom: calc(86px + env(safe-area-inset-bottom, 0px)) !important;
}
.toast { width: 100% !important; min-width: 0 !important; border-radius: 12px; }

/* ---------- Cards e listas (Focus) ---------- */
.card {
  padding: 16px !important;
  border-radius: 14px !important;
  margin-bottom: 12px;
}
.page-header {
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-bottom: 16px;
}
.page-header h1 {
  font-size: 22px !important;
  letter-spacing: -.4px;
  font-weight: 700;
}
.grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr !important; gap: 12px !important; }
.stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
.form-row { grid-template-columns: 1fr !important; gap: 12px !important; }

/* tabelas Focus em scroll horizontal suave */
.page table {
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
  scrollbar-width: none;
}
.page table::-webkit-scrollbar { display: none; }

/* ---------- Botões maiores em forms ---------- */
.btn, .btn-primary, .btn-secondary, .cmd-btn, .cmd-btn-primary {
  min-height: 44px;
  padding: 12px 16px;
  font-size: 14.5px;
  border-radius: 10px;
}
.btn-block { width: 100% !important; }

/* ---------- Tabela Command vira lista de cards ---------- */
.cmd-table { font-size: 14px !important; }
.cmd-table thead { display: none !important; }
.cmd-table, .cmd-table tbody { display: block !important; }
.cmd-table tbody tr {
  display: grid !important;
  grid-template-columns: auto 1fr auto;
  gap: 8px 10px;
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 8px;
  min-height: auto !important;
}
.cmd-table tbody tr > td {
  display: contents !important;
  border: 0 !important;
  padding: 0 !important;
}
/* só mostra td principais; resto fica em pseudo-cards */
.cmd-table tbody td.col-checkbox { grid-column: 1; align-self: start; }
.cmd-table tbody td.col-title {
  grid-column: 2;
  font-size: 15px; font-weight: 600;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.cmd-table tbody td.col-status { grid-column: 3; justify-self: end; }
.cmd-table tbody td.col-priority,
.cmd-table tbody td.col-due,
.cmd-table tbody td.col-assignees,
.cmd-table tbody td.col-team,
.cmd-table tbody td.col-updated,
.cmd-table tbody td.col-actions {
  grid-column: 1 / -1;
  font-size: 12.5px;
  color: var(--text2);
}
/* fallback geral pra quem não tem class col-* */
.cmd-table tbody td:not([class*="col-"]) {
  grid-column: 1 / -1;
  padding: 4px 0 !important;
  font-size: 13px;
}
.cmd-row-checkbox { width: 22px; height: 22px; }
.cmd-status, .cmd-priority { font-size: 11.5px; padding: 5px 10px; }
.cmd-table tr:hover { background: var(--surface) !important; }
.cmd-table tr:active { background: var(--surface2) !important; transform: scale(.99); transition: transform .08s; }

/* (regras de kanban consolidadas no bloco /tasks/kanban abaixo) */

/* ---------- KPIs scroll horizontal ---------- */
.rpt-cmd-kpis {
  display: flex !important;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  gap: 10px !important;
  padding: 0 14px 4px !important;
  margin: 0 -14px 16px !important;
  scrollbar-width: none;
  border: 0 !important;
}
.rpt-cmd-kpis::-webkit-scrollbar { display: none; }
.rpt-cmd-kpi {
  flex: 0 0 76% !important;
  scroll-snap-align: start;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px !important;
}
.rpt-cmd-section { margin: 12px 0 !important; }
.rpt-cmd-section-head { padding: 0 4px !important; }

/* ---------- Anti-overflow global em mobile ---------- */
html, body { max-width: 100vw; overflow-x: hidden; }
.main-wrap, .cmd-main-wrap {
  max-width: 100vw;
  overflow-x: hidden;
}
.page, .cmd-page {
  max-width: 100vw;
  overflow-x: hidden;
  box-sizing: border-box;
}
.page > *, .cmd-page > *,
.page .card, .cmd-page .card {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* ---------- Calendar mobile (conservador — só compacta, mantém estrutura) ---------- */
/* container externo: garante width 100% e sem overflow */
.cal-body, .cal-grid-outer, .cal-grid-inner,
.cal-nav-row, .cal-day-panel, .insights-panel,
.cal-upcoming, .cal-side-stack, .vis-notice {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow-x: hidden;
}
.cal-grid-outer { overflow: hidden; }
/* nav row mais compacta pra ganhar espaço lateral */
.cal-nav-row { padding: 8px 10px !important; gap: 6px !important; }
/* panels internos com padding menor */
.cal-day-panel, .insights-panel { padding: 14px !important; }
/* offset pro auto-scroll cair logo abaixo da topbar */
.cal-day-panel, #pcalDayPanel, .cal-side-stack { scroll-margin-top: 72px; }
.cal-upcoming { padding: 12px 14px !important; }
/* month-picker centrado e responsivo */
.month-picker { width: min(280px, calc(100vw - 32px)) !important; }
.month-picker-months { gap: 5px !important; }
/* grid 7 colunas: gap menor, sem min-width nas cells */
.cal-grid-inner > div, .cal-grid-inner > div > div {
  width: 100% !important;
  box-sizing: border-box;
}
.pcal-cell {
  min-height: 44px !important;
  min-width: 0 !important;
  width: auto !important;
  padding: 4px 2px !important;
  font-size: 12px;
  gap: 1px !important;
  box-shadow: none !important;
}
.pcal-cell .pcal-day-num { font-size: 12.5px; font-weight: 500; }
.pcal-cell.is-today .pcal-day-num { font-weight: 700; }

/* Seleção mais visível em mobile: scale + sombra + cor invertida */
.pcal-cell {
  transition: transform .14s cubic-bezier(.4,0,.2,1), box-shadow .14s ease, background .14s ease !important;
}
.pcal-cell.is-selected:not(.is-today) {
  background: var(--surface) !important;
  border-color: var(--text) !important;
  outline: 2px solid var(--text);
  outline-offset: -2px;
  box-shadow: 0 4px 10px rgba(0,0,0,.10) !important;
  transform: scale(1.06);
  z-index: 3;
  position: relative;
}
.pcal-cell.is-selected:not(.is-today) .pcal-day-num {
  color: var(--text) !important;
  font-weight: 700;
}
.pcal-cell.is-today.is-selected {
  transform: scale(1.06);
  z-index: 3;
  position: relative;
  outline: 2px solid var(--blue-fg, var(--text));
  outline-offset: -2px;
  box-shadow: 0 4px 10px rgba(0,0,0,.10) !important;
}
/* tap feedback nos dias */
.pcal-cell:not(.pcal-empty):active { transform: scale(.94); }
.pcal-cell.is-selected:not(.is-today):active,
.pcal-cell.is-today.is-selected:active { transform: scale(1.04); }
.pcal-dots { max-width: 100% !important; gap: 1.5px !important; flex-wrap: nowrap !important; overflow: hidden; }
.pcal-dot { width: 4px !important; height: 4px !important; }
/* esconde contador de tasks no canto pra liberar espaço */
.pcal-count { display: none !important; }
.pcal-ai-flag { width: 5px !important; height: 5px !important; top: 1px !important; right: 2px !important; }

/* Header dia da semana mais delicado */
.cal-grid-inner > div:first-child > div {
  font-size: 10px !important;
  padding: 2px 0 !important;
}

/* Side panel (cal-side-stack) ocupa full width em mobile, sem scrollbar visível */
.cal-side-stack {
  position: static !important;
  max-height: none !important;
  margin-top: 12px;
  overflow: visible !important;
  scrollbar-width: none;
}
.cal-side-stack::-webkit-scrollbar { display: none !important; }
/* esconde scrollbars de qualquer overflow horizontal/vertical em painéis do calendar */
.cal-page-wrap, .cal-page-wrap *::-webkit-scrollbar { display: none; }
.cal-page-wrap, .cal-page-wrap * { scrollbar-width: none !important; }

/* Cal-nav-row: wrap + tamanhos adequados pros botões caberem todos */
.cal-nav-row {
  flex-wrap: wrap !important;
  gap: 6px !important;
  padding: 10px 12px !important;
}
.cal-nav-row .btn-icon {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px;
  border-radius: 10px !important;
  background: var(--surface2);
  border: 1px solid var(--border);
}
.cal-nav-row .btn-icon svg { width: 14px !important; height: 14px !important; }
.cal-title-btn {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  font-size: 15px !important;
  padding: 6px 10px !important;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}
.cal-nav-row .btn.btn-sm {
  min-height: 38px !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
  border-radius: 10px !important;
}
#pcalInsightBadge {
  margin-left: auto !important;
  flex-basis: 100% !important;
  text-align: center;
  margin-top: 4px;
}
#pcalInsightBadge span { font-size: 11.5px !important; }

/* Page-header da calendar com filtros e botões: full-width segmented control + ícones */
.calendar-page .page-header,
body .page-header:has(.view-toggle) {
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 10px !important;
}
.page-header .ml-auto:has(.view-toggle),
.page-header > div:last-child:has(.view-toggle) {
  margin-left: 0 !important;
  width: 100%;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
/* view-toggle (Todos/Minhas/Pool) vira segmented control */
.view-toggle {
  display: inline-flex !important;
  background: var(--surface2) !important;
  border-radius: 999px !important;
  padding: 3px !important;
  gap: 2px !important;
  flex: 1 1 100% !important;
  width: 100%;
}
.vt-btn {
  flex: 1 !important;
  padding: 8px 12px !important;
  font-size: 13px !important;
  border-radius: 999px !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--text2) !important;
  font-weight: 500;
  min-height: 36px !important;
}
.vt-btn.active {
  background: var(--surface) !important;
  color: var(--text) !important;
  font-weight: 600 !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.08), 0 0 0 1px var(--border);
}
/* Botões "Nova tarefa" e "Novo lembrete": linha lado-a-lado fluida */
.page-header .btn-primary, .page-header .btn-ghost {
  flex: 1 1 auto !important;
  min-height: 42px !important;
  font-size: 13.5px !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  justify-content: center;
}
.cal-day-panel { padding: 14px !important; }
.insights-panel { padding: 14px !important; }
.ins-bar-wrap { height: 48px !important; }

/* Lista de eventos próximos (.up-event) — card normal sem min-width forçado */
.up-event {
  padding: 10px 12px !important;
  border-radius: 12px;
  gap: 10px !important;
  min-height: 0 !important;
}
.up-event .ue-date {
  min-width: 0 !important;
  width: auto !important;
  padding: 2px 0 2px 8px !important;
}
.up-event .ue-date .day { font-size: 18px !important; font-weight: 700; letter-spacing: -.4px; line-height: 1; }
.up-event .ue-date .mon { font-size: 9.5px !important; }
.up-event .ue-info { min-width: 0; flex: 1; overflow: hidden; }
.up-event .ue-info .ttl {
  font-size: 13.5px !important;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 2px;
}
.up-event .ue-info .meta { font-size: 11.5px !important; }
.up-event .ue-actions { gap: 2px; }
.up-event .ue-jump { min-width: 32px; min-height: 32px; }

/* ---------- Pull-to-refresh indicator ---------- */
.m-ptr {
  position: fixed;
  top: env(safe-area-inset-top, 0px);
  left: 50%;
  transform: translate(-50%, -60px);
  z-index: 235;
  width: 36px; height: 36px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,.10);
  transition: transform .18s cubic-bezier(.4,0,.2,1), opacity .18s ease;
  opacity: 0;
  pointer-events: none;
}
.m-ptr.show {
  opacity: 1;
}
.m-ptr.refreshing svg {
  animation: m-ptr-spin .8s linear infinite;
}
@keyframes m-ptr-spin {
  to { transform: rotate(360deg); }
}
.m-ptr svg {
  width: 18px; height: 18px;
  color: var(--text);
  transition: transform .14s ease;
}

/* ---------- Forms / inputs ---------- */
.form-group { margin-bottom: 14px; }
label { font-size: 13.5px; font-weight: 500; margin-bottom: 6px; display: block; }

/* ---------- Tabs / Pills ---------- */
.tabs, .cmd-tabs {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  white-space: nowrap;
  margin: 0 -14px 16px;
  padding: 0 14px;
}
.tabs::-webkit-scrollbar, .cmd-tabs::-webkit-scrollbar { display: none; }
.tab, .cmd-tab {
  flex-shrink: 0;
  min-height: 38px;
  padding: 8px 14px !important;
  font-size: 13.5px !important;
  border-radius: 999px !important;
}

/* ---------- Pull-to-refresh feel (visual hint) ---------- */
.main-wrap, .cmd-main-wrap {
  overscroll-behavior-y: contain;
}

/* ---------- Esconde elementos puramente desktop ---------- */
.cmd-page-stats .sep { display: none; }
.cmd-help-fab, .cmd-hint-card { display: none !important; }

/* ---------- Empty states ---------- */
.empty-state { padding: 48px 20px !important; text-align: center; }
.empty-state svg { width: 56px !important; height: 56px !important; opacity: .35; }
.empty-state h3 { font-size: 17px !important; margin: 14px 0 6px; }
.empty-state p { font-size: 14px; color: var(--text2); }

/* ---------- Sidebar nav já dentro do drawer mobile: dá respiro extra ---------- */
.sidebar-nav, .cmd-sidebar { padding-top: 8px; }
.user-card, .sidebar-actions { padding: 12px !important; }

/* ---------- Banner sticky (impersonate / superadmin / multi-empresa) ---------- */
#superadminBanner {
  font-size: 12px !important;
  padding: 8px 12px !important;
}

} /* end @media max-width 900px */


/* ================================================================
   Mobile-extra-small (≤ 380px) — refinos pra iPhone SE / Android compactos
   ================================================================ */
@media (max-width: 380px) {
  .page-header h1 { font-size: 19px !important; }
  .stats-grid { grid-template-columns: 1fr !important; }
  .m-bn-item { font-size: 9.5px; }
  .m-bn-item svg { width: 20px; height: 20px; }
  /* kanban-col regulada em bloco específico abaixo */
}


/* ================================================================
   Reduced motion
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  .modal, .sidebar, .cmd-sidebar, #taskDrawer, .notif-drawer, .m-fab, .m-bn-item {
    animation: none !important;
    transition: none !important;
  }
}


/* ================================================================
   Polish round 2 — efeitos nativos refinados
   ================================================================ */

@media (max-width: 900px) {

/* ---------- Topbar scroll-aware ---------- */
.topbar, .cmd-topbar {
  border-bottom-color: transparent !important;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
body.is-scrolled .topbar,
body.is-scrolled .cmd-topbar {
  border-bottom-color: var(--border) !important;
  box-shadow: 0 1px 0 var(--border), 0 4px 14px rgba(0,0,0,.04);
}

/* ---------- Segmented control (tabs/cmd-tabs em mobile viram pill switcher iOS) ---------- */
.tabs, .cmd-tabs {
  display: inline-flex !important;
  flex-wrap: nowrap !important;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 3px;
  gap: 2px !important;
  margin: 0 0 16px;
  width: max-content;
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}
.tabs::-webkit-scrollbar, .cmd-tabs::-webkit-scrollbar { display: none; }
.tab, .cmd-tab {
  flex-shrink: 0;
  padding: 7px 14px !important;
  font-size: 13px !important;
  font-weight: 500;
  border-radius: 999px !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--text2) !important;
  min-height: 32px !important;
  transition: background .18s ease, color .18s ease, transform .12s ease;
}
.tab:active, .cmd-tab:active { transform: scale(.96); }
.tab.active, .cmd-tab.active {
  background: var(--surface) !important;
  color: var(--text) !important;
  font-weight: 600;
  box-shadow: 0 1px 3px rgba(0,0,0,.08), 0 0 0 1px var(--border);
}

/* ---------- Toast → Snackbar (Material-ish) ---------- */
.toast-container {
  bottom: calc(86px + env(safe-area-inset-bottom, 0px)) !important;
  left: 12px !important; right: 12px !important;
  pointer-events: none;
}
.toast {
  background: rgba(28, 28, 30, .96) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 12px !important;
  padding: 13px 16px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  width: 100% !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.22) !important;
  animation: m-snackbar-in .3s cubic-bezier(.32,.72,0,1) !important;
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 12px;
}
.toast svg { color: #fff !important; }
.toast a { color: #4FC3F7 !important; font-weight: 600; text-decoration: none; }
@keyframes m-snackbar-in {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
[data-theme="dark"] .toast,
body.dark-theme .toast,
[data-layout="command"] .toast {
  background: rgba(244, 244, 245, .96) !important;
  color: #18181B !important;
}
[data-theme="dark"] .toast svg,
[data-layout="command"] .toast svg { color: #18181B !important; }

/* ---------- WhatsApp: extender stack mode pra 900px ---------- */
.wa-shell { width: 100% !important; }
.wa-sidebar { width: 100% !important; }
.wa-main { display: none; }
.wa-shell.chat-open .wa-sidebar { display: none; }
.wa-shell.chat-open .wa-main { display: flex !important; }
/* botão voltar injetado via JS no header da conversa */
.wa-back-btn {
  display: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: transparent;
  border: 0;
  align-items: center;
  justify-content: center;
  color: var(--wa-text, currentColor);
  cursor: pointer;
  flex-shrink: 0;
  margin-right: 4px;
}
.wa-back-btn:active { background: rgba(0,0,0,.08); }
.wa-shell.chat-open .wa-conv-head .wa-back-btn { display: inline-flex !important; }
/* esconde topbar e bottom nav durante chat aberto pra dar imersão */
.wa-shell.chat-open ~ .m-bn { display: none !important; }
body.has-mbn .wa-main { padding-bottom: 0; }

/* ---------- Page enter transition ---------- */
.page, .cmd-page {
  animation: m-page-in .26s cubic-bezier(.4,0,.2,1) both;
}
@keyframes m-page-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---------- Settings/users tabelas → cards stacked ---------- */
.users-table, .empresas-table, .settings-list-table {
  display: block;
}
.users-table thead, .empresas-table thead, .settings-list-table thead { display: none; }
.users-table tbody tr, .empresas-table tbody tr, .settings-list-table tbody tr {
  display: flex; flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 8px;
  gap: 6px 12px;
}
.users-table tbody td, .empresas-table tbody td, .settings-list-table tbody td {
  border: 0;
  padding: 0;
  font-size: 13px;
}

/* ---------- Skeleton loader (visual quando JS marcar elemento) ---------- */
.m-skeleton {
  background: linear-gradient(90deg, var(--surface2) 25%, var(--bg3, var(--bg)) 50%, var(--surface2) 75%);
  background-size: 200% 100%;
  animation: m-skeleton 1.4s ease-in-out infinite;
  border-radius: 8px;
}
@keyframes m-skeleton {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ================================================================
   Polish específico — /meets /reports /teams (views menos visitadas)
   ================================================================ */

/* ---------- /meets ---------- */
.meets-grid {
  grid-template-columns: 1fr !important;
  gap: 10px !important;
}
.meet-card {
  padding: 14px !important;
  border-radius: 12px !important;
}
/* No touch o hover não existe — botões de ação sempre visíveis */
.meet-actions {
  opacity: 1 !important;
  top: 10px !important;
  right: 10px !important;
}
.meet-actions .btn-icon {
  width: 36px; height: 36px;
  background: var(--surface2);
  border-radius: 8px;
}
.meet-card-header { gap: 10px !important; margin-bottom: 12px !important; }
.meet-card-header > div:nth-child(2) > div:first-child {
  /* permite título quebrar em 2 linhas no mobile (sem ellipsis agressivo) */
  white-space: normal !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  /* mantém ellipsis se passar de 2 linhas */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.meet-meta { gap: 8px 14px !important; font-size: 11.5px !important; }
.meet-meta span { line-height: 1.3; }

/* ---------- /teams ---------- */
.grid-3 {
  grid-template-columns: 1fr !important;
  gap: 12px !important;
}
.team-card {
  padding: 16px !important;
  border-radius: 12px !important;
}
.team-card .btn-icon {
  width: 36px; height: 36px;
  background: var(--surface2);
  border-radius: 8px;
}
/* Member picker no modal de criar/editar equipe */
#memberPicker {
  max-height: 240px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 12px !important;
  gap: 6px !important;
}
#memberPicker label {
  padding: 8px 12px !important;
  font-size: 13px !important;
  min-height: 36px;
  border: 1px solid var(--border);
}
/* Color input maior pra toque */
#teamColor { height: 48px !important; min-height: 48px; }

/* ---------- /reports ---------- */
.page-header > .ml-auto {
  width: 100%;
  margin-top: 8px;
  margin-left: 0 !important;
  justify-content: flex-start;
  flex-wrap: wrap;
}
/* Filtros: cada select ocupa largura útil, fácil de tocar */
.rpt-filters {
  gap: 8px !important;
  margin-bottom: 16px !important;
}
.rpt-filters select {
  flex: 1 1 calc(50% - 8px);
  min-height: 40px;
  padding: 8px 10px !important;
  font-size: 13.5px !important;
  border-radius: 10px !important;
}
/* KPIs em 2 colunas (antes era auto-fit minmax 180 = 1 coluna em telinha) */
.rpt-kpi-grid {
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 10px !important;
  margin-bottom: 18px !important;
}
.rpt-kpi {
  padding: 12px 14px !important;
  border-radius: 12px !important;
}
.rpt-kpi-value { font-size: 22px !important; }
.rpt-kpi-label { font-size: 10.5px !important; }
.rpt-kpi-icon { display: none; } /* polui em telinha */
/* Cards com gráfico: padding menor + altura ajustada */
.rpt-card {
  padding: 14px !important;
  border-radius: 12px !important;
}
.rpt-chart-wrap { height: 220px !important; }
.rpt-chart-wrap.sm { height: 160px !important; }
/* Tabelas viram scroll horizontal — não força lista pra preservar layout */
.rpt-table {
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
}
.rpt-table th, .rpt-table td {
  padding: 9px 8px !important;
  font-size: 12.5px !important;
}
.rpt-meet-val { font-size: 15px !important; }
.rpt-grid-main, .rpt-grid-3, .rpt-grid-2 {
  grid-template-columns: 1fr !important;
  gap: 12px !important;
}

/* ---------- Empty states em geral (centralizado, padding seguro) ---------- */
.empty-state {
  padding: 48px 20px !important;
  text-align: center;
}
.empty-state svg { opacity: .5; }

/* ================================================================
   /tasks (lista) — header e filtros compactos pra mobile
   ================================================================ */

/* Header da página: empilha h1 em cima e ações abaixo */
.page > .page-header,
.cmd-page > .page-header {
  flex-wrap: wrap;
  gap: 8px !important;
  align-items: center !important;
  margin-bottom: 10px !important;
}
.page > .page-header > h1,
.cmd-page > .page-header > h1 {
  font-size: 22px !important;
  margin-bottom: 0 !important;
}
.page > .page-header > .ml-auto {
  margin-left: 0 !important;
  width: 100%;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  justify-content: flex-start;
  gap: 6px !important;
  padding-bottom: 2px;
}
.page > .page-header > .ml-auto::-webkit-scrollbar { display: none; }
.page > .page-header > .ml-auto > * { flex-shrink: 0; }

/* Toggle Lista/Kanban: cada parte tocável */
.page-header > .ml-auto > [style*="border-radius"][style*="overflow:hidden"] > .btn {
  min-height: 36px;
  padding: 7px 10px !important;
  font-size: 13px !important;
}

/* Card de filtros: COMPACTO. Pills em linha rolável + selects abaixo */
.page > .card.mb-4 {
  padding: 8px 10px !important;
  margin-bottom: 12px !important;
  border-radius: 12px !important;
}
.page > .card.mb-4 > [style*="display:flex"][style*="flex-wrap:wrap"] {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* tornar a linha rolável horizontal — todas as pílulas em linha */
}
.page > .card.mb-4 > [style*="display:flex"]::-webkit-scrollbar { display: none; }
.page > .card.mb-4 > [style*="display:flex"] > * { flex-shrink: 0; }

/* Pills de filtro principais: tamanho compacto */
.page > .card.mb-4 > [style*="display:flex"] > a.btn-sm,
.page > .card.mb-4 > [style*="display:flex"] > .btn-sm {
  min-height: 32px;
  padding: 6px 12px !important;
  font-size: 12.5px !important;
  border-radius: 999px !important;
  font-weight: 500;
}

/* Selects: compactos lado a lado, pílula */
.page > .card.mb-4 select.form-control {
  width: auto !important;
  min-height: 32px !important;
  padding: 6px 28px 6px 12px !important;
  font-size: 12.5px !important;
  border-radius: 999px !important;
  background-position: right 8px center;
  border: 1px solid var(--border) !important;
}

/* Divider vertical some, ml-auto vira inline também */
.page > .card.mb-4 [style*="width:1px"][style*="height:20px"] { display: none !important; }
.page > .card.mb-4 [style*="margin-left:auto"] {
  margin-left: 0 !important;
  flex-shrink: 0;
  flex-direction: row;
  gap: 6px !important;
  align-items: center;
}
.page > .card.mb-4 [style*="margin-left:auto"] .btn-sm {
  min-height: 32px;
  padding: 6px 10px !important;
  font-size: 11.5px !important;
  border-radius: 999px !important;
}
/* Contador de tarefas vira span discreto à direita */
.page > .card.mb-4 [style*="margin-left:auto"] > span {
  white-space: nowrap;
  font-size: 11px;
  color: var(--text3);
  margin-left: 4px;
}

/* Tasks list: linhas touch-friendly */
.task-row {
  padding: 12px 14px !important;
  min-height: 60px;
}
.task-row .task-title {
  font-size: 14px !important;
  font-weight: 600;
}
.task-row .task-meta {
  gap: 5px !important;
  flex-wrap: wrap;
  margin-top: 5px !important;
}
.task-row .task-meta .badge,
.task-row .task-meta .tag {
  font-size: 10.5px !important;
  padding: 2px 7px !important;
  min-height: 22px;
}
.task-row .avatar {
  width: 30px !important; height: 30px !important;
  font-size: 12px !important;
}

/* ================================================================
   /tasks/kanban — coluna centralizada com peek + dots fixos
   ================================================================ */

/* Math do center-snap:
   - col width = calc(100vw - 48px)
   - container padding-inline = 24px  (= (100vw - colWidth)/2 → primeira coluna naturalmente centralizada quando scroll=0)
   - gap entre colunas: 12px
   - peek visível dos lados: 24px (igual ao padding) */
.kanban,
.kanban-board {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: visible !important;
  scroll-snap-type: x mandatory !important;
  -webkit-overflow-scrolling: touch;
  gap: 12px !important;
  padding: 0 24px 16px !important;
  /* margin negativo cancela padding do .page (14px em mobile) pra board ocupar a tela toda */
  margin: 0 -14px !important;
  scrollbar-width: none;
  scroll-behavior: smooth;
}
.kanban::-webkit-scrollbar,
.kanban-board::-webkit-scrollbar { display: none; }

.kanban-col {
  flex: 0 0 calc(100vw - 48px) !important;
  width: calc(100vw - 48px) !important;
  min-width: 0 !important;
  max-width: none !important;
  scroll-snap-align: center !important;
  scroll-snap-stop: always !important;
  border-radius: 14px !important;
  padding: 12px !important;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  display: flex !important;
  flex-direction: column;
}

.kanban-col-header {
  padding: 4px 4px 12px !important;
  display: flex !important;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.kanban-col-title { font-size: 13.5px !important; font-weight: 700; }
.kanban-col-count {
  background: var(--surface2);
  color: var(--text2);
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 999px;
  margin-left: auto;
}
.kanban-col-body { flex: 1; padding-bottom: 6px; min-height: 80px; }
.kanban-task {
  padding: 12px !important;
  border-radius: 10px;
  margin-bottom: 8px !important;
}

/* Dots de página fixos no rodapé (acima do bottom-nav) */
.kanban-dots {
  position: fixed;
  left: 0; right: 0;
  bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  display: flex;
  justify-content: center;
  gap: 6px;
  padding: 8px 0;
  pointer-events: auto;
  z-index: 200;
  background: linear-gradient(to top, var(--bg, #F4F4F2) 60%, transparent);
}
.kanban-dot {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--border-strong, #C4C4C4);
  transition: all .2s ease;
  flex-shrink: 0;
  border: 0; padding: 0;
  cursor: pointer;
}
.kanban-dot.active {
  width: 22px;
  background: var(--text);
}

/* Sort row do kanban: scroll horizontal */
.page > div[style*="display:flex"][style*="margin-bottom:12px"] {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 4px;
  gap: 6px !important;
}
.page > div[style*="display:flex"][style*="margin-bottom:12px"]::-webkit-scrollbar { display: none; }
.page > div[style*="display:flex"][style*="margin-bottom:12px"] > * { flex-shrink: 0; }

/* Espaço extra no fim do board pra dots não cobrirem cards */
.page:has(.kanban-dots) { padding-bottom: 60px !important; }
.cmd-page:has(.kanban-dots) { padding-bottom: 60px !important; }

/* ================================================================
   Task drawer — barra fixa de status no rodapé do drawer (mobile)
   ================================================================ */

/* O drawer ocupa 100vh em mobile. A barra de status fica fixa no bottom. */
#taskDrawer {
  padding-bottom: 0 !important;
}
.m-drawer-status-bar {
  position: fixed;
  left: 0; right: 0;
  bottom: 0;
  z-index: 460;
  background: var(--bg2, #fff);
  border-top: 1px solid var(--border);
  display: flex;
  gap: 8px;
  padding: 12px 14px calc(12px + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -4px 16px rgba(0,0,0,.06);
  /* só visível enquanto o drawer estiver aberto — controlado por classe no body */
  transform: translateY(100%);
  transition: transform .22s cubic-bezier(.32,.72,0,1);
  pointer-events: none;
}
body.drawer-open .m-drawer-status-bar {
  transform: translateY(0);
  pointer-events: auto;
}
.m-drawer-status-bar button {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  font-family: inherit;
  cursor: pointer;
  min-height: 48px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.m-drawer-status-bar button:active {
  background: var(--surface2);
  transform: scale(.97);
}
.m-drawer-status-bar button:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.m-drawer-status-bar button svg { width: 14px; height: 14px; flex-shrink: 0; }
.m-drawer-status-bar .next {
  background: var(--text);
  color: var(--primary-fg, #FAFAF9);
  border-color: var(--text);
}
.m-drawer-status-bar .next:active { background: var(--primary-hover, #27272A); }
.m-drawer-status-bar .label { overflow: hidden; text-overflow: ellipsis; }

/* Quando barra existe, drawer ganha padding bottom pra conteúdo não passar por baixo */
body.drawer-open #drawerInner { padding-bottom: 78px !important; }

/* ================================================================
   /users (lista) — tabela compacta + actions como ícones em mobile
   ================================================================ */
#tab-usuarios .card { padding: 0 !important; overflow: hidden; }
#tab-usuarios .card > div[style*="overflow-x"] { overflow-x: visible !important; }
#tab-usuarios table { display: block; }
#tab-usuarios thead, #tab-usuarios tbody { display: block; }
#tab-usuarios thead { display: none; }
#tab-usuarios tbody tr { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 8px; padding: 10px 12px; border-bottom: 1px solid var(--hairline); }
#tab-usuarios tbody td { padding: 0 !important; border: 0 !important; flex-shrink: 0; }
#tab-usuarios tbody td:nth-child(1) { flex: 1 1 100%; min-width: 0; order: 1; }
#tab-usuarios tbody td:nth-child(1) > div { gap: 8px !important; }
#tab-usuarios tbody td:nth-child(1) > div > div:nth-child(2) { flex: 1; min-width: 0; }
#tab-usuarios tbody td:nth-child(1) > div > div:nth-child(2) > div:first-child { font-size: 13px !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#tab-usuarios tbody td:nth-child(1) > div > div:nth-child(2) > div:last-child { font-size: 10.5px !important; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#tab-usuarios tbody td:nth-child(1) svg { display: none !important; }
#tab-usuarios tbody td:nth-child(2) { flex: 0 0 auto; order: 5; flex-basis: 100%; padding-top: 4px !important; }
#tab-usuarios tbody td:nth-child(2) .badge { font-size: 10.5px; padding: 3px 8px; }
#tab-usuarios tbody td:nth-child(2) select.form-control { font-size: 12px; padding: 5px 8px !important; height: 30px; }
#tab-usuarios tbody td:nth-child(3),
#tab-usuarios tbody td:nth-child(4) { display: none !important; }
#tab-usuarios tbody td:nth-child(5) { order: 2; }
#tab-usuarios tbody td:nth-child(5) > div { gap: 5px !important; }
#tab-usuarios tbody td:nth-child(5) > div > div:first-child { width: 30px !important; height: 5px !important; }
#tab-usuarios tbody td:nth-child(5) span { font-size: 11px !important; }
#tab-usuarios tbody td:nth-child(6) { order: 3; }
#tab-usuarios tbody td:nth-child(6) > div { gap: 3px !important; flex-wrap: nowrap !important; }
#tab-usuarios tbody td:nth-child(6) .btn-sm {
  padding: 6px !important; min-height: 32px; min-width: 32px; font-size: 0 !important;
  border: 1px solid var(--border); border-radius: 6px;
}
#tab-usuarios tbody td:nth-child(6) .btn-sm svg { width: 13px; height: 13px; }
#tab-usuarios tbody td:nth-child(6) .btn-sm:not(:has(svg)) { font-size: 10.5px !important; padding: 6px 8px !important; min-width: auto; }
#tab-usuarios tbody tr[id^="user-stats-"] { padding: 0 !important; }
#tab-usuarios tbody tr[id^="user-stats-"] td { display: block !important; padding: 12px 14px !important; background: var(--surface2); flex-basis: 100%; }

/* Tabs Users compactas */
.user-tabs-wrap { gap: 4px !important; padding: 4px !important; }
.user-tab { padding: 8px 12px !important; font-size: 12.5px !important; }

} /* end @media max-width 900px */


/* ================================================================
   Standalone / PWA mode (instalado como app)
   ================================================================ */
@media (display-mode: standalone) {
  .topbar, .cmd-topbar { padding-top: env(safe-area-inset-top, 20px) !important; }
  /* hide browser-only chrome quando instalado como app */
  body { user-select: none; -webkit-user-select: none; }
  .page, .cmd-page, p, span, .modal-body { user-select: text; -webkit-user-select: text; }
}

/* ================================================================
   System dark preference (caso user não tenha tema definido)
   ================================================================ */
@media (prefers-color-scheme: dark) {
  html:not([data-theme]) body:not(.dark-theme) {
    /* só aplica se user não escolheu tema explicitamente */
  }
}
