/* 
 * style-mobile.css - CSS Mobile-First para Elyon
 * Carregado condicionalmente: <link media="(max-width: 768px)">
 * Nao afeta desktop. Complementa as media queries ja existentes no style.css.
 * Criado: 01/04/2026
 */

/* ── Header compacto ──────────────────────────────────────── */
.app-header {
  padding: 0.4rem 0.75rem;
}
.header-logo-text { display: none; }
.header-logo img { width: 28px; height: 28px; }
.header-right .user-badge { display: none; }
.header-right .btn-sair { font-size: 0.7rem; padding: 0.25rem 0.5rem; }

/* ── Sidebar overlay ──────────────────────────────────────── */
.sidebar {
  z-index: 1000;
  box-shadow: 4px 0 20px rgba(0,0,0,0.5);
}
.sidebar.open ~ .main-content::before {
  content: '';
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.4);
  z-index: 999;
}

/* ── Main content full width ──────────────────────────────── */
.main-content {
  margin-left: 0 !important;
  padding: 0.75rem !important;
}

/* ── Page header empilhado ────────────────────────────────── */
.page-header {
  flex-direction: column;
  gap: 0.5rem;
  align-items: flex-start;
}
.page-title { font-size: 1.1rem; }
.page-actions {
  width: 100%;
  display: flex;
  gap: 0.5rem;
}
.page-actions .btn-primary,
.page-actions .btn-secondary {
  flex: 1;
  font-size: 0.8rem;
  padding: 0.5rem;
}

/* ── Dashboard ────────────────────────────────────────────── */
.dash-filtro-row {
  flex-direction: column;
  gap: 0.5rem;
}
.dash-status-filter {
  flex-wrap: wrap;
  gap: 0.25rem;
}
.dash-filtro-select {
  width: 100%;
  max-width: 100%;
}
.btn-pdf-dash { width: 100%; }

/* Dashboard cards resumo */
.dash-resumo-cards {
  flex-direction: column;
}
.dash-resumo-card {
  min-width: 100%;
}

/* STATUS GERAL tabela - scroll horizontal */
.dashboard-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.sg-table {
  min-width: 600px;
}
.sg-nome { font-size: 0.75rem; white-space: nowrap; }
.sg-val { font-size: 1rem; }
.sg-val-colab { font-size: 0.8rem; }

/* Dashboard linhas projeto - scroll horizontal */
.dash-linha-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Dashboard mini-tabelas */
.dash-mini-tables {
  flex-direction: column;
}
.dash-mini-table {
  min-width: 100%;
}

/* Dashboard donut/charts */
.dash-donut-row {
  flex-direction: column;
}

/* ── Obras ────────────────────────────────────────────────── */
.obras-filtros {
  flex-direction: column;
  gap: 0.5rem;
}
.obras-filtros input,
.obras-filtros select {
  width: 100%;
  min-width: 0;
}
.obras-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.obras-table {
  min-width: 800px;
}

/* Obras formulario */
.form-grid {
  grid-template-columns: 1fr !important;
}
.form-group.span-2,
.form-group.span-3 {
  grid-column: span 1 !important;
}
.obra-save-bar {
  flex-direction: column;
  gap: 0.5rem;
}
.obra-save-bar button { width: 100%; }

/* ── Atividades ───────────────────────────────────────────── */
.table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table-wrap table {
  min-width: 1000px;
}
.col-toggle-wrap {
  flex-wrap: wrap;
  gap: 0.25rem;
}

/* ── Cronograma ───────────────────────────────────────────── */
.cron-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ── Pecas ────────────────────────────────────────────────── */
.pecas-filtros {
  flex-direction: column;
  gap: 0.5rem;
}
.pecas-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ── Producao ─────────────────────────────────────────────── */
.prod-resumo-cards {
  flex-direction: column;
}
.prod-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.prod-tabs {
  flex-wrap: wrap;
  gap: 0.25rem;
}
.prod-tabs button {
  flex: 1;
  min-width: calc(33% - 0.25rem);
  font-size: 0.75rem;
  padding: 0.4rem;
}

/* ── Timesheet ────────────────────────────────────────────── */
.ts-form-row {
  flex-direction: column;
  gap: 0.5rem;
}
.ts-form-row select,
.ts-form-row input {
  width: 100%;
}
.ts-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ── Kanban ───────────────────────────────────────────────── */
.kb-board {
  flex-direction: column;
}
.kb-column {
  min-width: 100%;
  max-width: 100%;
}
.kb-filtros {
  flex-direction: column;
  gap: 0.5rem;
}
.kb-filtros select { width: 100%; }

/* ── Chat (complementa existente) ─────────────────────────── */
.chat-layout {
  flex-direction: column;
}
.chat-sidebar {
  width: 100%;
  max-height: 200px;
  overflow-y: auto;
  border-bottom: 1px solid var(--border);
  border-right: none;
}
.chat-main {
  flex: 1;
}
.chat-sidebar-hidden { display: none; }

/* ── Calculista ───────────────────────────────────────────── */
.calc-stepper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.calc-kpis {
  flex-wrap: wrap;
}
.calc-kpi {
  min-width: calc(50% - 1px);
}

/* ── Financeiro ───────────────────────────────────────────── */
.fin-resumo-cards {
  flex-direction: column;
}
.fin-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.fin-tabs {
  flex-wrap: wrap;
}
.fin-tabs button {
  flex: 1;
  min-width: calc(33% - 0.25rem);
  font-size: 0.75rem;
}

/* ── Usuarios ─────────────────────────────────────────────── */
.users-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ── Modal confirmacao ────────────────────────────────────── */
.confirm-box {
  min-width: unset;
  max-width: 90%;
  margin: 0 1rem;
}

/* ── Geral ────────────────────────────────────────────────── */
.btn-primary, .btn-secondary {
  font-size: 0.8rem;
}
.empty-state, .loading-state {
  font-size: 0.85rem;
  padding: 1.5rem;
}


/* ── FIXES ROUND 2 (01/04/2026) ─────────────────────────── */

/* Dashboard: checkboxes status em 2 linhas */
.dash-status-filter {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.2rem 0.5rem;
}
.sg-filter-label { font-size: 0.7rem; }

/* Atividades: header compacto */
#tab-atividades .page-header {
  gap: 0.4rem;
}
#tab-atividades .page-header select {
  width: 100%;
  font-size: 0.8rem;
}
#tab-atividades .page-actions {
  display: flex;
  gap: 0.4rem;
  width: 100%;
}
#tab-atividades .page-actions button {
  flex: 1;
  font-size: 0.75rem;
  padding: 0.4rem;
}
/* Atividades: toggle Colunas/Tabela/Kanban compacto */
.col-toggle-wrap button,
.view-toggle button {
  font-size: 0.7rem;
  padding: 0.3rem 0.5rem;
}

/* Producao: cards resumo em grid 2x2 */
.prod-resumo-cards,
.resumo-cards {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}
.prod-resumo-card,
.resumo-card {
  min-width: unset !important;
}
.resumo-valor { font-size: 1.1rem; }
.resumo-label { font-size: 0.65rem; }

/* Producao: tabs menores */
.prod-tabs {
  gap: 0.15rem;
}
.prod-tabs button {
  font-size: 0.65rem;
  padding: 0.35rem 0.3rem;
}

/* Chat: sidebar como lista colapsável no topo */
.chat-layout {
  flex-direction: column;
  height: calc(100vh - 120px);
}
.chat-sidebar {
  width: 100% !important;
  max-width: 100% !important;
  min-width: unset !important;
  max-height: 180px;
  overflow-y: auto;
  border-right: none !important;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.chat-main {
  flex: 1;
  min-height: 0;
}
.chat-obra-item {
  padding: 0.5rem 0.75rem;
}
.chat-obra-nome { font-size: 0.8rem; }
.chat-obra-preview { font-size: 0.7rem; }

/* Chat: input area compacto */
.chat-input-area {
  padding: 0.4rem;
}
.chat-input {
  font-size: 0.85rem;
}

/* Calculista: stepper scroll horizontal */
.calc-stepper {
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  gap: 0.25rem;
}
.calc-step {
  min-width: 55px;
  font-size: 0.65rem;
}
/* Calculista: KPIs 2x2 */
.calc-kpis {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
}

/* Financeiro: tabela valores não cortar */
.fin-table td {
  white-space: nowrap;
  font-size: 0.75rem;
}

/* Usuarios: emails truncados */
.users-table td {
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Cronograma: garantir que carrega */
#tab-cronograma .page-header select {
  width: 100%;
}
.cron-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.cron-table {
  min-width: 700px;
}

/* Tabelas gerais: font menor no mobile */
table td, table th {
  font-size: 0.75rem;
  padding: 0.4rem 0.3rem;
}

/* Scroll indicator (sombra direita em containers com scroll) */
.table-wrap,
.dashboard-table-wrap,
.obras-table-wrap,
.pecas-table-wrap,
.prod-table-wrap,
.fin-table-wrap,
.ts-table-wrap,
.users-table-wrap,
.cron-table-wrap {
  position: relative;
}
.table-wrap::after,
.dashboard-table-wrap::after,
.obras-table-wrap::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 20px;
  background: linear-gradient(to left, rgba(0,0,0,0.08), transparent);
  pointer-events: none;
}
