/* Used by default.server.tsx */
.section {
  max-inline-size: 1000px;
  margin: 1rem auto;
  padding-inline: 1rem;
  overflow: hidden;
}

.header {
  display: flex;
  align-items: center;
  margin-block: 1rem;

  h2 {
    margin: 0;
    font-size: 2rem;
  }

  mark {
    background: linear-gradient(90deg in hsl, #a0ffff88, #d1a2ff88) bottom left / 100% 50% no-repeat;
    padding: 0.1rem;
  }
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}

.attribution {
  color: #666;
  font-size: 0.8em;
  margin-block-end: 2rem;
}

.hint {
  display: inline-flex;
  gap: 0.5rem;
  font-size: 0.8em;
  line-height: 1;
  opacity: 0.5;
  transition: opacity 150ms;
  user-select: none;

  &:hover {
    opacity: 1;
  }
}

/* Used by Celebrate.client.tsx */
.button {
  background: linear-gradient(90deg in oklch, #a0ffff, #d1a2ff) #ccc;
  transition:
    filter 500ms,
    transform 150ms,
    box-shadow 150ms;
  display: block;
  margin-inline: auto;
  padding: 1rem;
  border: none;
  filter: grayscale(100%);
  overflow: hidden;
  border-radius: 99px;
  box-shadow: 0 0 0.25rem 0 #2442;
  font-weight: bold;
  cursor: pointer;

  &:hover,
  &:focus {
    transform: scale(1.1);
    box-shadow: 0 0.25rem 1rem 0 #4884;
  }
}

.before {
  display: inline-block;
  transition:
    transform 300ms,
    opacity 300ms;
}

.after {
  position: absolute;
  left: 0;
  right: 0;
  opacity: 0;
  transform: translateY(150%);
  transition:
    transform 300ms,
    opacity 300ms;
}

.hydrated {
  filter: none;

  .before {
    opacity: 0;
    transform: translateY(-150%);
  }

  .after {
    opacity: 1;
    transform: translateY(0);
  }
}
