
.hp-books {
  grid-gap: var(--large-gap);  
}

.hp-books__section {
  padding-top: 64px;
  padding-bottom: 64px;
}

.hp-books__title {
  margin-bottom: 32px;
}

.hp-books__footer {
  margin-top: 32px;
}


/* Special homepage thumbnails */
.hp-book {
  --padding: 16px;
}

.hp-book .thumb__link {
  display: grid;
  grid-template-columns: 1fr 1.33333fr;
  margin-bottom: 0;
  padding: var(--padding);
  border-bottom: none;
  gap: var(--padding);
  transition: none;
  position: relative;
}

.hp-book.thumb .thumb__title  {
  font-size: var(--font-size-h2);
  font-weight: 500;
  margin-bottom: 16px;
}

.hp-book .thumb__content {
  padding-left: var(--padding);
  position: relative;  
}

.hp-book .thumb__content:before {
  content: '';
  position: absolute;
  top: calc(-1 * var(--padding));
  bottom: calc(-1 * var(--padding));
  left: 0px;
  border-left: 2px solid var(--color-light);
}

.hp-book .thumb__link:after {
  content: ''; position: absolute;
  bottom: 0; left: 0; right: 0;
  border-bottom: 4px solid transparent;
  transition: 0.25s all ease-out;
}

@media (pointer: fine) {
  .hp-book .thumb__link:hover:after {
    border-color: var(--color-dark);
  }
}

.hp-book .thumb__title {
  font-size: var(--font-size-h2);
  margin-bottom: 16px;
}

.hp-book .thumb__writers  {
  font-weight: bold;
}

/* Transition */
.push.push--index {
  transition-delay: calc(var(--push-index)* 0.1s);
}

.push.in-viewport {
  transform: none;
  transition: 0.75s cubic-bezier(0.42, 0, 0.15, 0.99);
  opacity: 1;
}

.push {
  transform: translateY(35px);
  opacity: 0;
  transition: none;
}

/* Mobile */
@media (max-width: 1000px) {
  .hp-books__section {
    padding-top: 32px;
    padding-bottom: 32px;
  }

  .hp-books {
    gap: 16px;
  }

  .hp-book {
    --padding: 9.5px;
  }

  .hp-book.thumb .thumb__title {
    font-size: var(--font-size-h3);
    font-weight: bold;
    margin-bottom: 9.5px;
  }

  .hp-book .thumb__writers {
    font-weight: normal;
  }

  .hp-books__footer {
    margin-top: 22px;
  }
}

@media (max-width: 500px) {
  .hp-books {
    grid-template-columns: 1fr;
  }
}