/* filter-bar.css — Filter bar do Painel + fp-panel (filtro de Período).
   Extraído de components.css na Fase C da modularização. */

/* ════════════════════════════════════
   FILTER BAR
   Layout: grid auto-fill com cada cell de 220px mínimo. Todas as filter-items
   compartilham a mesma altura interna (label 18px + gap 6px + control 36px).
════════════════════════════════════ */
.filter-bar {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px 14px;
  padding: 4px 0 18px;
  align-items: start;
}
/* Cada filter-item ocupa exatamente 1 cell do grid e força largura 100% nos
   filhos (select nativo, ss-trigger ou fpTriggerSlot do PeriodPicker). */
.filter-item {
  display: flex; flex-direction: column; gap: 6px;
  min-width: 0;             /* essencial para não estourar o grid track */
  width: 100%;
}
.filter-item > * { min-width: 0; }
.filter-item .filter-label { white-space: nowrap; }
.filter-item .filter-select { width: 100%; min-width: 0; max-width: 100%; }
.filter-item .ss-wrap { width: 100%; min-width: 0; }
.filter-item .ss-trigger { width: 100%; min-width: 0; flex: 1; max-width: none; }
.filter-item #fpTriggerSlot { width: 100%; min-width: 0; }
.filter-item #fpTriggerSlot > * { width: 100%; min-width: 0; }
.filter-label {
  display: flex; align-items: center; gap: 6px;
  height: 18px;             /* altura fixa do label alinha visualmente todos */
  font-size: .8rem; font-weight: 600;
  color: var(--text-muted); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.filter-icon { width: 14px; height: 14px; flex-shrink: 0; }
.filter-select {
  /* Onda 7.6: min-width 240px removido — colidia com grid track 220px e
     estourava o layout, causando o desalinhamento dos filtros do Painel. */
  height: 36px; padding: 0 36px 0 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface); color: var(--text);
  font-size: .82rem; font-family: var(--font);
  cursor: pointer;
  width: 100%; min-width: 0; max-width: 100%;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; background-size: 16px;
  transition: border-color .15s, box-shadow .15s;
}
.filter-select:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(67,97,238,.12);
}
.filter-select:disabled { opacity: .5; cursor: not-allowed; }
[data-theme="dark"] .filter-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
}

/* Separador vertical entre filtros — oculto no layout de grade */
.filter-sep { display: none; }

/* Filtro de Período */
.filter-select--periodo { min-width: 150px; max-width: 180px; }

.filter-periodo-wrap {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}

.filter-periodo-dates {
  display: flex; align-items: center; gap: 6px;
}
.filter-periodo-dates.hidden { display: none; }

.filter-date-input {
  height: 36px; padding: 0 10px; width: 118px;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--surface); color: var(--text);
  font-size: .82rem; font-family: var(--font);
  transition: border-color .15s, box-shadow .15s;
}
.filter-date-input:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(67,97,238,.12);
}
[data-theme="dark"] .filter-date-input { background: var(--surface); }

.filter-date-sep {
  color: var(--text-muted); font-weight: 600; font-size: .9rem;
}

/* Onda 7.5: regras .fp-* deletadas — markup removido na Onda 7.4
   (PeriodPicker organism cria seu próprio popover com classes .cmp-period-picker__*). */

