/* ========== Filter Form Styling ========== */

/* Label styling */
.filter-label {
  min-width: 100px;
  max-width: 120px;
  font-size: 0.5rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
body {
  background-color: #fafafa;
}

/* Input size */
.filter-input-sm {
  font-size: 2rem;
  height: 26px;
}

/* Icon Search Hover Effect */
.search-icon-hover {
  background: transparent;
  border-left: none;
  padding: 0 0.5rem;
  cursor: pointer;
  transition: all 0.2s ease;
}
.search-icon-hover:hover svg {
  transform: scale(1.1);
  color: #0d6efd;
}

/* Button style */
.btn-filter-custom {
 padding: px 1px 1px px;
  font-size: 0.8rem;
  min-height: 32px;
  transition: all 0.3s ease;
}
.btn-filter-custom:hover {
  background-color: #0056b3;
  box-shadow: 0 0 8px rgba(0, 86, 179, 0.6);
}
.btn-filter-custom:disabled {
  opacity: 0.6;
  pointer-events: none;
}

/* Spinner animation */
.spin-animation {
  animation: spin 1s linear infinite;
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.data-page-layout {
  padding: 1rem;
  font-size: 0.85rem;
}

.filter-section .card {
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  background-color: #fafafa;
}

.table-section {
  margin-top: 1rem;
}

#loadingMessage {
  font-size: 0.85rem;
  color: #555;
}
