.tile {
  text-shadow: var(--text-shadow);
  border-radius: var(--border-radius-large);
  background-color: var(--color-primary);
}

.tile__link {
  display: block;
  height: 100%;
  text-decoration: none;
  color: var(--color-white);
}

.tile__link:hover .tile__title,
.tile__link:focus .tile__title {
  text-decoration: underline;
  text-decoration-thickness: 3px;
}

.tile__link:focus .tile__image img,
.tile__link:hover .tile__image img {
  transform: scale(1.03);
}

.tile__inner {
  height: 100%;
  display: grid;
  grid-template-areas:
    "image"
    "text";
}

.tile__image {
  position: relative;
  overflow: hidden;
  grid-row-start: image-start;
  grid-row-end: text-end;
  grid-column-start: image-start;
  grid-column-end: text-end;
  border-radius: var(--border-radius-large);
}

.tile__image::after {
  position: absolute;
  inset: 0;
  content: "";
  border-radius: var(--border-radius-large);
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.4) 100%);
}

.tile__link:focus .tile__image::after,
.tile__link:hover .tile__image::after {
  opacity: 0.3;
  background-color: var(--color-black);
}

.tile__image img {
  width: 100%;
  object-fit: cover;
  min-height: 270px;
}

.tile__content {
  position: relative;
  z-index: 1;
  grid-row-start: text-start;
  grid-row-end: text-end;
  grid-column-start: text-start;
  grid-column-end: text-end;
  margin-top: auto;
  padding: var(--spacing-large);
}

.tile__title {
  margin-bottom: 0;
  color: var(--color-white);
}

.tile__content>*+* {
  margin-top: var(--spacing);
}

.layout--bg-1 .tile,
.layout--bg-4 .tile,
.layout--bg-5 .tile {
  text-shadow: none;
}
