/* -- Date nav row --------------------------------------------------- */
.roster-date-nav {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.roster-date-nav .btn-icon-nav {
  width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--border-color, #e2e8f0); border-radius: 6px;
  background: var(--bg-primary, #fff); cursor: pointer; color: var(--text-secondary, #475569);
  transition: background 0.15s;
}
.roster-date-nav .btn-icon-nav:hover:not(:disabled) { background: var(--bg-hover, #f1f5f9); }
.roster-date-nav .btn-icon-nav:disabled { opacity: 0.4; cursor: not-allowed; }
.roster-date-nav .flatpickr-input { width: 130px; text-align: center; }

/* -- Gap badge ------------------------------------------------------ */
.gap-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 10px; border-radius: 12px; font-size: 12px; font-weight: 600;
  background: #fef2f2; color: #b91c1c; white-space: nowrap;
}
.gap-badge--zero { background: #dcfce7; color: #166534; }

/* -- Entry pills ---------------------------------------------------- */
.entry-pill {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600;
  margin: 1px 2px; white-space: nowrap; cursor: pointer;
  transition: filter 0.15s;
}
.entry-pill:hover { filter: brightness(0.92); }
.entry-pill--auto { font-style: italic; }

/* -- Status dot ----------------------------------------------------- */
.status-dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
}
.status-dot--green { background: #16a34a; }
.status-dot--red   { background: #dc2626; }

/* -- Installer link inside AG Grid ---------------------------------- */
.installer-link {
  color: var(--primary, #3b82f6); text-decoration: none; font-weight: 500;
}
.installer-link:hover { text-decoration: underline; }

/* -- Modal autocomplete wrapper ------------------------------------- */
.autocomplete-wrap { position: relative; }
.autocomplete-results {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 210;
  max-height: 200px; overflow-y: auto;
  background: #fff; border: 1px solid var(--border-color, #e2e8f0);
  border-radius: 6px; box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}
.autocomplete-results[hidden] { display: none; }

/* -- Confirmation strip (delete) ------------------------------------ */
.confirm-strip {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: #fef2f2; border-radius: 6px; margin-top: 8px;
  font-size: 13px; color: #b91c1c;
}
.confirm-strip .btn { font-size: 12px; padding: 4px 12px; }

/* -- Info banner (auto-created) ------------------------------------- */
.info-banner {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  background: #eff6ff; border: 1px solid #bfdbfe; border-radius: 8px;
  font-size: 13px; color: #1e40af; margin-bottom: 12px;
}
.info-banner[hidden],
.confirm-strip[hidden],
.gap-badge[hidden],
[hidden] { display: none !important; }
.info-banner a { color: #1d4ed8; font-weight: 600; }
