#output {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  grid-template-rows: 1fr;
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  list-style: none;
  padding: 0;
  margin: 2rem 0;
}

div#output a {
  display: block;
  width: 100%;
  height: 100%;
  background: #eaeaea;
  box-shadow: #03a9f4 0px 5px;
  text-decoration: none;
  color: #000;
}

.event-info {
  padding: 1rem 1rem 1.5rem;
}

#output a img {
  width: 100%;
  height: auto;
}

/* Add spinner styles */
.loader {
  border: 4px solid #f3f3f3;
  border-top: 4px solid #3498db;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  animation: spin 2s linear infinite;
  margin: 20px auto;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* Custom styles for pagination buttons and spinner */
.pagination-container {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
}

.pagination-container button {
  flex: 1;
}

.loading-spinner {
  display: none;
  margin-top: 20px;
}

/* Additional styles for GOV.UK Design System pagination component */
.govuk-pagination__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}

.govuk-pagination__list-item {
  display: inline;
  margin-right: 5px;
}

.govuk-pagination__list-item:last-child {
  margin-right: 0;
}

.govuk-pagination__link {
  display: inline-block;
  padding: 5px 10px;
  border: 1px solid #1d70b8;
  color: #1d70b8;
  text-decoration: none;
  font-weight: bold;
}

.govuk-pagination__link:hover {
  background-color: #1d70b8;
  color: #ffffff;
}

.govuk-pagination__link.govuk-pagination__link--selected {
  background-color: #1d70b8;
  color: #ffffff;
  cursor: default;
}

ul#paginationControls {
    display: flex;
    padding: 0;
    margin: 0;
    list-style: none;
}