.text-linked-media {
    width: 100%;
}

.text-linked-media__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: start;
}

.text-linked-media__text {
text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 100%;
}

.text-linked-media__heading {
    font-family: 'landmark inline', sans-serif;
        max-width: 640px;
}

.text-linked-media__textarea {
	max-width: 400px;
	text-wrap: pretty;
}

.text-linked-media__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 20px;
}

.text-linked-media__item {
    position: relative;
    display: block;
    aspect-ratio: 3 / 5;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
}

.text-linked-media__item:focus-visible {
    outline: 2px solid var(--primary-colour);
    outline-offset: 2px;
}

.text-linked-media__media-inner {
    position: absolute;
    inset: 0;
}

.text-linked-media__image,
.text-linked-media__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}

/* Hover effect for linked items */
a.text-linked-media__item .text-linked-media__overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0);
    transition: background 0.4s ease;
    z-index: -1;
}

a.text-linked-media__item:hover .text-linked-media__image,
a.text-linked-media__item:hover .text-linked-media__video {
    transform: scale(1.08);
}

a.text-linked-media__item:hover .text-linked-media__overlay::before {
    background: rgba(0, 0, 0, 0.15);
}

.text-linked-media__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 1.5rem;
    z-index: 1;
}

.text-linked-media__overlay-text {
    color: #fff;
}

@media (max-width: 900px) {
    .text-linked-media__layout {
        grid-template-columns: 1fr;
    }

    .text-linked-media__textarea {
        max-width: 100%;
    }
}
