.shaft-search .search-card {
  background: #fff;
  padding: 2rem;
  border-radius: 1rem;
}

.shaft-search .search-card .input-group > .form-control {
  border-radius: 50px 0 0 50px;
}

.shaft-search .search-card .input-group > .btn-primary {
  border-radius: 0 50px 50px 0;
}

.shaft-search .search-card .filter-btn {
  border-radius: 50%;
  margin-left: .5rem;
}

.sort-controls {
  width: 100%;
}

.sort-controls .form-select {
  border-radius: 50px;
}

.shaft-search .results {
  background: #fff;
  border-radius: 1rem;
  padding: 1.5rem;
}

@media (max-width: 576px) {
  .shaft-search {
    padding-left: 0;
    padding-right: 0;
  }

  .shaft-search .results {
    padding: 0.5rem;
  }

  .shaft-search .row.g-3 {
    --bs-gutter-x: 0.5rem;
    --bs-gutter-y: 0.5rem;
  }

  .shaft-search .card-body {
    padding: 0.75rem;
  }
}

#filterOffcanvas .form-label {
  font-weight: 600;
  color: #6c757d;
  font-size: 0.9rem;
}

#filterOffcanvas .d-flex.flex-wrap .btn,
#filterOffcanvas .d-flex.gap-2 .btn {
  border-radius: 50px;
}

#filterOffcanvas .shaft-type-group,
#filterOffcanvas .kick-point-group {
  display: grid;
  gap: 0.5rem;
}

#filterOffcanvas .shaft-type-group {
  grid-template-columns: repeat(2, 1fr);
}

#filterOffcanvas .kick-point-group {
  grid-template-columns: repeat(5, 1fr);
}

#filterOffcanvas .shaft-type-group .btn,
#filterOffcanvas .kick-point-group .btn {
  width: 100%;
  border-radius: 50px;
}

#filterOffcanvas .filter-box {
  max-height: 200px;
  overflow-y: auto;
  border: 1px solid #dee2e6;
  border-radius: .5rem;
  padding: .5rem;
}

#filterOffcanvas .flex-group {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
}

#filterOffcanvas .flex-group .btn {
  flex: 1 1 0;
  border-radius: 50px;
  white-space: nowrap;
}

#filterOffcanvas .flex-group .btn.flex-other {
  flex: 2 1 0;
}

#filterOffcanvas .range-input {
  display: flex;
  align-items: center;
  border: 1px solid #ced4da;
  border-radius: 50px;
  overflow: hidden;
}

#filterOffcanvas .range-input .form-select,
#filterOffcanvas .range-input .form-control {
  flex: 1;
  border: none;
}

#filterOffcanvas .range-input .range-separator {
  padding: 0 .5rem;
  color: #6c757d;
}
