/* ══════════════════════════════════════════════════════════════════════════
   Design System Overrides — Alfa Solution
   Aplica tokens e refinamentos visuais do design system da Alfa Company.
   Este arquivo se sobrepõe ao <style> de index.html sem modificá-lo.
   ══════════════════════════════════════════════════════════════════════════ */

/* ── 1. Tokens adicionais ── */
:root {
  --gold:        #B9A97A;
  --gold-glow:   rgba(185,169,122,0.22);
  --gold-border: rgba(185,169,122,0.18);
  --carbon-02:   #1B1D1F;
}

/* ── 2. Tipografia — Montserrat em botões e labels de seção ── */
.btn,
.btn-p, .btn-s, .btn-grn, .btn-blu,
.btn-primary, .btn-secondary, .btn-danger,
.imp-action-btn, .dash-period-btn, .imp-fmt-btn {
  font-family: 'Montserrat', sans-serif;
  letter-spacing: 0.015em;
}

.sb-label {
  font-family: 'Montserrat', sans-serif;
  letter-spacing: 0.12em;
}

/* ── 3. Botões — Pill shape + sombra refinada ── */
.btn {
  border-radius: 9999px;
}

.btn-p {
  background: linear-gradient(135deg, #AA9563 0%, #B9A97A 60%, #c4ad75 100%);
  box-shadow: 0 4px 16px rgba(185,169,122,0.38);
}
.btn-p:hover {
  background: linear-gradient(135deg, #B9A97A 0%, #c4ad75 60%, #AA9563 100%);
  box-shadow: 0 6px 24px rgba(185,169,122,0.55), 0 0 0 1px rgba(185,169,122,0.2);
  transform: translateY(-1px);
}

.btn-s {
  border-color: var(--gold-border);
}
.btn-s:hover {
  border-color: var(--gold);
  color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold-border), var(--shadow);
}

.btn-grn {
  border-radius: 9999px;
}
.btn-blu {
  border-radius: 9999px;
}

.dash-period-btn {
  border-radius: 9999px;
}
.dash-period-btn.on {
  background: linear-gradient(135deg, #AA9563, var(--gold));
  border-color: transparent;
  box-shadow: 0 2px 10px rgba(185,169,122,0.35);
}

.imp-fmt-btn:hover,
.imp-fmt-btn.sel {
  border-color: var(--gold);
  background: rgba(185,169,122,0.08);
  color: var(--gold);
}

/* ── 4. Cards (KPI, card, stat-bar, mkpi) ── */

/* Shimmer sweep — replica .component-card::before do design system */
@keyframes ds-shimmer {
  from { left: -100%; }
  to   { left: 100%; }
}

/* ── Ambient backdrop — gradientes radiais para o blur ter algo a desfocar ── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 45% at 8% 12%,  rgba(185,169,122,0.07) 0%, transparent 55%),
    radial-gradient(ellipse 45% 55% at 92% 88%, rgba(185,169,122,0.05) 0%, transparent 55%),
    radial-gradient(ellipse 35% 35% at 50% 45%, rgba(122,144,176,0.03) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

/* ── Glass base — igual ao .glass do design system ── */
.kpi, .card, .stat-bar, .mkpi {
  background: rgba(27, 29, 31, 0.55);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border-color: rgba(185, 169, 122, 0.18);
  border-top-color: rgba(185, 169, 122, 0.35);
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(185, 169, 122, 0.10);
}

.kpi:hover, .card:hover, .stat-bar:hover {
  background: rgba(27, 29, 31, 0.68);
  border-color: rgba(185, 169, 122, 0.35);
  box-shadow:
    0 16px 48px rgba(0, 0, 0, 0.55),
    0 0 40px rgba(185, 169, 122, 0.07),
    inset 0 1px 0 rgba(185, 169, 122, 0.12);
}

.kpi {
  border-color: rgba(185,169,122,0.12);
  border-radius: 1.25rem;
}
.kpi:hover {
  border-color: rgba(185,169,122,0.3);
}
.kpi::before {
  background: linear-gradient(90deg, var(--gold), rgba(185,169,122,0.25));
}
.kpi::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(185,169,122,0.04), transparent);
  pointer-events: none;
  transition: left 0.6s ease;
}
.kpi:hover::after {
  left: 100%;
}
.kpi.kpi-active {
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 1px var(--gold), 0 8px 24px rgba(185,169,122,0.2) !important;
}
.kpi.kpi-active::after {
  background: var(--gold);
  top: auto;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 3px;
  transition: none;
  border-radius: 0 0 1.25rem 1.25rem;
}

.card {
  position: relative;          /* necessário para ::after { position: absolute } ficar dentro do card */
  border-color: rgba(185,169,122,0.1);
  border-radius: 1.25rem;
}
.card::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(185,169,122,0.04), transparent);
  pointer-events: none;
  transition: left 0.6s ease;
}
.card:hover::after {
  left: 100%;
}

.stat-bar {
  border-color: rgba(185,169,122,0.1);
}
.stat-bar:hover {
  border-color: rgba(185,169,122,0.25);
}
.stat-bar.kpi-active {
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 1px var(--gold), 0 6px 20px rgba(185,169,122,0.18) !important;
}

.mkpi {
  border-color: rgba(185,169,122,0.1);
}
.mkpi:hover {
  border-color: rgba(185,169,122,0.25);
}
.mkpi::before {
  background: linear-gradient(90deg, var(--mkpi-accent, var(--gold)), transparent);
}

/* ── 5. Tabelas — Gold border no header ── */
.tbl th {
  border-bottom: 1.5px solid var(--gold-border);
  color: var(--t2);
}
.tbl tbody tr:nth-child(odd) td {
  background: rgba(185, 169, 122, 0.012);
}
.tbl tbody tr:hover td:first-child {
  box-shadow: inset 3px 0 0 var(--gold);
}

/* ── 6. Forms / Inputs — Focus glow 3px gold ── */
.f input:focus,
.f select:focus,
.f textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--gold-glow);
}

.srch input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--gold-glow);
}

.sel:hover {
  border-color: rgba(185,169,122,0.4);
}
.sel:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--gold-glow);
  outline: none;
}

.login-field input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--gold-glow), 0 0 20px rgba(185,169,122,0.07);
}

.imp-dre-sel:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--gold-glow);
  outline: none;
}

/* ── 7. Sidebar — Active item + toggle refinados ── */
.nav.on {
  background: rgba(185,169,122,0.12);
  box-shadow: inset 0 0 0 1px var(--gold-border);
}
.nav.on::before {
  background: linear-gradient(180deg, var(--gold), #AA9563);
  box-shadow: 0 0 10px rgba(185,169,122,0.55);
}
.sb-toggle:hover {
  background: var(--gold);
  border-color: var(--gold);
  box-shadow: 0 0 14px rgba(185,169,122,0.45);
}

/* ── 8. Badges — Gold badge refinado ── */
.b-badge {
  background: rgba(185,169,122,0.12);
  color: var(--gold);
  border: 1px solid var(--gold-border);
}

/* ── 9. Progress bar — Altura 6px + gradient gold ── */
.prog {
  height: 6px;
  border-radius: 3px;
}
.prog-f {
  background: linear-gradient(90deg, #AA9563, var(--gold));
  box-shadow: 0 0 8px rgba(185,169,122,0.35);
}

/* ── 10. Toast — Border radius maior ── */
.toast {
  border-radius: 14px;
  border-left-width: 4px;
}

/* ── 11. Topbar — Bottom border gold sutil ── */
.topbar {
  border-bottom-color: var(--gold-border);
  box-shadow: 0 1px 0 var(--gold-border);
}

/* ── 12. Modal — Borda e sombra refinadas ── */
.modal {
  border-color: var(--gold-border);
  box-shadow: var(--shadow-lg), 0 0 80px rgba(185,169,122,0.06);
}
.mh {
  border-bottom-color: var(--gold-border);
}
.modal-sm {
  border-color: var(--gold-border);
}

/* Drill overlay box */
.drill-box {
  border-color: var(--gold-border);
}
.drill-head {
  border-bottom-color: var(--gold-border);
}

/* ── 13. Login — Glow border ── */
.login-box {
  border-color: var(--gold-border);
  box-shadow: 0 32px 80px rgba(0,0,0,0.55), 0 0 0 1px var(--gold-border), 0 0 60px rgba(185,169,122,0.06);
}
.login-btn {
  border-radius: 9999px;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: 0.02em;
}

/* ── 14. Import modal refinements ── */
.imp-result-box {
  border-color: var(--gold-border);
}
.imp-stat-card {
  border-color: var(--gold-border);
}
.imp-stat-card:hover {
  border-color: rgba(185,169,122,0.35);
}
.imp-action-btn {
  border-radius: 9999px;
}
.imp-action-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
}

/* ── 15. Card header (ch) — Border refinada ── */
.ch {
  border-bottom-color: var(--gold-border);
}

/* ── 16. Alert cards — Border dourada nos neutros ── */
.alert-b {
  border-color: var(--gold-border);
}

/* ── 17. Live dot — Gold accent ── */
.live-dot {
  color: var(--gold);
}
.live-dot::before {
  background: var(--gold);
}

/* ── 19. Glass — cards secundários ── */
.imp-stat-card {
  background: linear-gradient(135deg, rgba(27,29,31,0.75) 0%, rgba(18,20,21,0.58) 100%);
  backdrop-filter: blur(10px) saturate(130%);
  -webkit-backdrop-filter: blur(10px) saturate(130%);
  box-shadow: 0 4px 16px rgba(0,0,0,0.22), inset 0 1px 0 rgba(185,169,122,0.06);
}

.alert-b {
  background: linear-gradient(135deg, rgba(27,29,31,0.70) 0%, rgba(18,20,21,0.55) 100%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* ── 20. Glass — modal e drill overlay ── */
.modal {
  background: rgba(27, 29, 31, 0.88);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
}

.drill-box {
  background: rgba(27, 29, 31, 0.88);
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
}

/* ── 21. Glass — dashboard filter bar ── */
.dash-filter-bar {
  background: linear-gradient(135deg, rgba(27,29,31,0.72) 0%, rgba(18,20,21,0.55) 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* ── 22. Lucide icons — estilos base para ícones do design system ── */
i[data-lucide] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  pointer-events: none;
}

.ib i[data-lucide],
#mobile-menu-btn i[data-lucide],
.gs-icon i[data-lucide] {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.gs-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── 23. EFO Mapa de Desempenho — indicator row filter ── */
.efo-mapa-label:hover {
  color: var(--gold) !important;
}

/* ── 18. Scrollbar — Gold thumb ── */
::-webkit-scrollbar-thumb {
  background: rgba(185,169,122,0.25);
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(185,169,122,0.45);
}

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVIDADE COMPLETA — Overrides multiplataforma
   Cobertura: 320px · 480px · 768px · 1024px · 1200px · 1440px · 1920px+
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Step 1: 100dvh fix + safe-area ── */
@supports (height: 100dvh) {
  .app  { height: 100dvh; }
  .sb   { min-height: 100dvh; }
  .main { height: 100dvh; }
  body  { min-height: 100dvh; }
  .pq-view { height: 100dvh; }
}

@media (max-width: 768px) {
  .sb {
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  .modal {
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  @supports (max-height: 100dvh) {
    .modal { max-height: 92dvh !important; }
    .modal-box { max-height: 100dvh !important; }
  }
}

/* ── Step 2: Login responsivo ── */
@media (max-width: 480px) {
  #login-screen {
    padding: 16px;
  }
  .login-box {
    width: calc(100vw - 32px) !important;
    max-width: 420px;
    padding: 32px 24px;
    border-radius: 16px;
  }
  #login-logo-svg {
    width: 90px;
    height: 90px;
  }
  .login-title { font-size: 18px; }
  .login-sub { font-size: 11px; }
  .login-tagline { font-size: 9px; margin-bottom: 20px; }
  .login-field input {
    padding: 12px 14px;
    font-size: 14px; /* previne zoom iOS */
  }
  .login-btn {
    padding: 13px;
    font-size: 13px;
  }
}

@media (max-width: 320px) {
  .login-box {
    width: calc(100vw - 16px) !important;
    padding: 24px 16px;
    border-radius: 12px;
  }
  #login-logo-svg {
    width: 72px;
    height: 72px;
  }
  .login-title { font-size: 16px; }
  .login-field input { padding: 10px 12px; }
  .login-btn { padding: 11px; font-size: 12px; }
}

/* ── Step 3: Touch targets mobile ── */
@media (max-width: 768px) {
  /* Icon buttons */
  .ib {
    width: 40px;
    height: 40px;
    font-size: 16px;
  }

  /* Buttons */
  .btn, .btn-p, .btn-s, .btn-grn, .btn-blu {
    min-height: 40px;
  }

  /* Form inputs — font-size 14px previne zoom iOS */
  .f input, .f select, .f textarea,
  .rb-field select, .rb-field input,
  .sel,
  .efo-form-row input, .efo-form-row select, .efo-form-row textarea,
  .efo-filter-select {
    min-height: 42px;
    font-size: 14px;
  }

  /* Search */
  .srch input,
  #global-search {
    min-height: 40px;
    font-size: 14px;
  }

  /* Tabs */
  .tab, .eq-stab, .efo-tab, .efo-sub-tab {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
  }

  /* Modal close */
  .mh-close {
    width: 40px;
    height: 40px;
    font-size: 18px;
  }

  /* Drill close */
  .drill-close {
    width: 44px;
    height: 44px;
  }

  /* Collaborator items */
  .cl {
    min-height: 48px;
    padding: 10px 14px;
  }

  /* Pref rows */
  .pref-row {
    min-height: 48px;
    padding: 12px 0;
  }

  /* Nav items */
  .nav {
    min-height: 40px;
  }

  /* Notif button */
  .notif-btn {
    width: 40px;
    height: 40px;
  }
}

/* ── Step 4: Breakpoint 320px ── */
@media (max-width: 320px) {
  /* KPIs: 1 coluna */
  .kpi-grid,
  .drag-zone[style*="repeat("] {
    grid-template-columns: 1fr !important;
  }

  /* Stat bars: 1 coluna */
  .drag-zone[style*="stat-bar"],
  #dz-dash-kpi2, #dz-gest-kpi2 {
    grid-template-columns: 1fr !important;
  }

  /* Padding menor */
  .view { padding: 8px !important; }
  .kpi { padding: 8px 10px; }
  .kpi-value { font-size: 16px !important; }
  .kpi-label, .kpi-l { font-size: 9px; }

  /* Header: stacked */
  .ph { gap: 8px; }
  .ph-title { font-size: 15px !important; white-space: normal; }
  #page-title { max-width: 120px; }

  /* Botoes: wrap + compact */
  .ph > div:last-child {
    flex-wrap: wrap;
    width: 100%;
  }
  .ph .btn, .ph .btn-p, .ph .btn-s {
    font-size: 11px;
    padding: 6px 10px;
    flex: 1;
    justify-content: center;
  }

  /* Modal: mais apertado */
  .mh { padding: 10px 12px; }
  .mh-title { font-size: 13px !important; }
  .mb { padding: 10px 12px 16px; }

  /* Bottom nav compact */
  .mob-nav-item { font-size: 8px; padding: 3px 1px; }
  .mob-nav-icon { font-size: 14px; }

  /* Cards */
  .card { padding: 10px; }
  .ch { padding: 10px 12px; }

  /* Modal KPI grids */
  #mtab-fin-kpis,
  .mb div[style*="repeat("] {
    grid-template-columns: 1fr !important;
  }

  /* MKPIs */
  .mkpi-grid, .mkpi-grid-4 { grid-template-columns: 1fr !important; }

  /* Report KPIs */
  .rp-kpi-grid { grid-template-columns: 1fr !important; }
  #rel-kpis { grid-template-columns: 1fr !important; }

  /* EFO */
  .efo-kpi-grid { grid-template-columns: 1fr !important; }

  /* Stat bar compact */
  .stat-bar { padding: 8px 10px; gap: 6px; }
  .stat-bar .kpi-value { font-size: 16px !important; }
  .stat-bar .kpi-label { font-size: 9px; }

  /* Topbar */
  .topbar { padding: 0 10px; height: 48px; }
  .crumb { font-size: 12px; }
}

/* ── Step 5: Tipografia fluida ── */
.ph-title   { font-size: clamp(16px, 2.5vw, 24px); }
.ph-sub     { font-size: clamp(11px, 1.5vw, 13px); }
.mh-title   { font-size: clamp(13px, 2vw, 17px); }
.kpi-value  { font-size: clamp(18px, 3vw, 28px); }
.kpi-label,
.kpi-l      { font-size: clamp(9.5px, 1.2vw, 11px); }
.ch-title   { font-size: clamp(12px, 1.5vw, 14px); }
.login-title { font-size: clamp(16px, 3vw, 22px); }
.efo-kpi-val { font-size: clamp(16px, 2.5vw, 22px); }
.rp-kpi-val { font-size: clamp(16px, 2.5vw, 19px); }
.rp-title   { font-size: clamp(14px, 2vw, 17px); }

/* ── Step 6: Drill overlay responsivo ── */
@media (max-width: 768px) {
  .drill-overlay {
    align-items: flex-end;
  }
  .drill-box {
    width: 100vw;
    max-width: 100vw;
    max-height: 92dvh;
    border-radius: 16px 16px 0 0;
  }
  .drill-head { padding: 14px 16px; }
  .drill-head h3 { font-size: 14px; }
  .drill-body { padding: 14px 16px; }
  .drill-table { font-size: 11px; }
  .drill-table th { padding: 6px 8px; font-size: 9.5px; }
  .drill-table td { padding: 8px; }
}

@media (max-width: 480px) {
  .drill-box { max-height: 96dvh; }
  .drill-head { padding: 12px 14px; }
  .drill-body { padding: 12px 14px; }
  .drill-table { font-size: 10.5px; }
  .drill-table th { font-size: 9px; }
}

/* ── Step 7a: Calendario responsivo ── */
@media (max-width: 768px) {
  .eq-cal-grid { gap: 2px; }
  .eq-cal-day { min-height: 52px; padding: 3px; }
  .eq-cal-day-num { font-size: 10px; }
  .eq-cal-dot { font-size: 8px; padding: 1px 2px; }
}

@media (max-width: 480px) {
  .eq-cal-grid { gap: 1px; }
  .eq-cal-day { min-height: 40px; padding: 2px; border-radius: 4px; }
  .eq-cal-day-hd { font-size: 9px; padding: 3px 1px; }
  .eq-cal-day-num { font-size: 9px; }
  /* Eventos viram dots */
  .eq-cal-dot {
    font-size: 0;
    width: 6px; height: 6px;
    padding: 0;
    border-radius: 50%;
    background: var(--org);
    border-left: none;
    display: inline-block;
    margin: 1px;
  }
}

@media (max-width: 320px) {
  .eq-cal-day { min-height: 32px; }
}

/* ── Step 7b: Organograma responsivo ── */
@media (max-width: 768px) {
  .eq-org-card {
    min-width: 100px;
    max-width: 130px;
    padding: 8px 10px;
  }
  .eq-org-ava { width: 28px; height: 28px; font-size: 10px; }
  .eq-org-name { font-size: 10px; max-width: 100px; }
  .eq-org-role-lbl { font-size: 8px; }
  .eq-org-card.org-root { min-width: 120px; }
  .eq-org-tree li { padding: 16px 6px 0; }
}

@media (max-width: 480px) {
  .eq-org-card { min-width: 80px; max-width: 100px; padding: 6px 8px; }
  .eq-org-name { font-size: 9px; max-width: 80px; }
  .eq-org-tree li { padding: 12px 4px 0; }
}

/* ── Step 8: Table column hiding ── */
@media (max-width: 768px) {
  /* Ranking: esconde Setor e Meta */
  #t-rank th:nth-child(3),
  #t-rank td:nth-child(3),
  #t-rank th:nth-child(6),
  #t-rank td:nth-child(6) {
    display: none;
  }

  /* Empresas: esconde Segmento e Meta */
  #t-emp-c th:nth-child(2),
  #t-emp-c td:nth-child(2),
  #t-emp-c th:nth-child(5),
  #t-emp-c td:nth-child(5) {
    display: none;
  }

  /* Integracoes: esconde Proxima Sync */
  #t-integracoes th:nth-child(6),
  #t-integracoes td:nth-child(6) {
    display: none;
  }

  /* Celulas mais compactas */
  .tbl td, .tbl th { padding: 8px 10px; }
}

@media (max-width: 480px) {
  /* Ranking: tambem esconde Crescimento */
  #t-rank th:nth-child(7),
  #t-rank td:nth-child(7) {
    display: none;
  }

  /* Empresas: tambem esconde Crescimento */
  #t-emp-c th:nth-child(6),
  #t-emp-c td:nth-child(6) {
    display: none;
  }

  /* Integracoes: tambem esconde Ultima Sync */
  #t-integracoes th:nth-child(5),
  #t-integracoes td:nth-child(5) {
    display: none;
  }

  /* Padding bem compacto */
  .tbl td, .tbl th { padding: 6px 6px; font-size: 11px; }
}

/* ── Step 9a: EFO KPI grid transicoes suaves ── */
@media (max-width: 1200px) and (min-width: 961px) {
  .efo-kpi-grid { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 960px) and (min-width: 561px) {
  .efo-kpi-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ── Step 9b: Report builder 480px ── */
@media (max-width: 480px) {
  .report-builder { padding: 14px 16px; }
  .rp-kpi-grid { grid-template-columns: 1fr !important; }
  .rp-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  #report-preview { padding: 14px 16px; }
  .report-card { padding: 14px 16px; }
  .report-card-icon { width: 36px; height: 36px; font-size: 16px; margin-bottom: 10px; }
}

/* ── Step 10: Power Query responsivo ── */
@media (max-width: 1024px) {
  .pq-header { padding: 10px 14px; gap: 10px; }
  .pq-title { font-size: 13px; }
  .pq-config { width: 240px; min-width: 240px; }
}

@media (max-width: 768px) {
  /* Sidebar vira drawer esquerdo */
  .pq-sidebar {
    position: fixed;
    left: 0; top: 0; bottom: 0;
    z-index: 560;
    width: 260px; min-width: 260px;
    transform: translateX(-100%);
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 4px 0 32px rgba(0,0,0,0.5);
  }
  .pq-sidebar.pq-panel-open {
    transform: translateX(0);
  }

  /* Config vira drawer direito */
  .pq-config {
    position: fixed;
    right: 0; top: 0; bottom: 0;
    z-index: 560;
    width: 280px; min-width: 280px;
    transform: translateX(100%);
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: -4px 0 32px rgba(0,0,0,0.5);
  }
  .pq-config.pq-panel-open {
    transform: translateX(0);
  }

  /* Overlay */
  .pq-panel-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 555;
  }
  .pq-panel-overlay.show { display: block; }

  /* Toggle buttons mobile */
  .pq-mob-toggle {
    display: flex !important;
    width: 36px; height: 36px;
    align-items: center; justify-content: center;
    background: var(--bg2);
    border: 1px solid var(--line2);
    border-radius: var(--r);
    cursor: pointer;
    color: var(--t2);
    font-size: 16px;
    flex-shrink: 0;
    transition: all 0.15s;
  }
  .pq-mob-toggle:hover { border-color: var(--org); color: var(--org); }

  /* Header compact */
  .pq-header {
    padding: 8px 12px;
    flex-wrap: wrap;
    gap: 8px;
  }

  /* Action bar: scroll horizontal */
  .pq-action-bar {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .pq-action-bar::-webkit-scrollbar { display: none; }
  .pq-act-btn { flex-shrink: 0; }

  /* Status bar compact */
  .pq-statusbar { gap: 8px; padding: 4px 12px; font-size: 10px; flex-wrap: wrap; }

  /* Table area full width */
  .pq-table-area { min-width: 0; }
}

/* PQ toggle buttons hidden no desktop */
.pq-mob-toggle { display: none; }
