/* PAGE */

#p-2025-09-22-trpil {
	/* Page-specific value, for image aspect ratio */
	--image-aspect: 1.5;
}

#p-2025-09-22-trpil .p-main-padding {
	padding: 0 1rem;
}

@media (min-width: 768px) {
	#p-2025-09-22-trpil .p-main-padding {
		padding: 0 2rem;
	}
}

/* BLOCKQUOTE */

#p-2025-09-22-trpil blockquote {
	border-left: 2px solid #ccc;
	padding-left: 16px;
}

/* COLUMN LAYOUT AND MAX-WIDTH CONTAINER */

#p-2025-09-22-trpil .p-container {
	--column-max-width: 420px;
	position: relative;
	margin: 0 auto;
	max-width: var(--column-max-width);
	display: flex;
	flex-direction: column;
	gap: 32px;
	padding-bottom: 96px;
}

@media (min-width: 768px) {
	#p-2025-09-22-trpil .p-container {
		--column-gap: max(40px, 5vw);
		max-width: calc(var(--column-max-width) * 2 + var(--column-gap));
		flex-direction: row;
		flex-wrap: nowrap;
		gap: var(--column-gap);
		align-items: flex-start;
	}
}

/*

TODO: SORT STYLES BELOW INTO GPS

*/

/* COLUMN POSITIONING */

.flex-column {
	position: relative;
	flex: 1 0 0%;
}

.column-one {
	position: relative;
}

@media (min-width: 768px) {
	.column-one {
		position: sticky;
		top: 0;
	}
}

/* COLUMN PADDING, FOR POSITIONING */

.column-padding {
	/* Carefully calculated padding centers the image in the viewport,
        bumped up 1rem for optical correction. We apply this padding
        to both the "image" and "text" columns to start from a place
        where both columns are vertically aligned. */
	--image-height: calc(100% * var(--image-aspect));
	--image-height-half: calc(var(--image-height) / 2);
	--min-padding-top: 3rem;
	--optical-correction: 0px;
	--column-padding-top: max(
		var(--min-padding-top),
		calc(50vh - var(--image-height-half) - var(--optical-correction))
	);
}

.column-one-padding {
	padding-top: var(--column-padding-top);
}

.column-two-padding {
	padding-top: 1rem;
}

@media (min-width: 768px) {
	.column-two-padding {
		padding-top: var(--column-padding-top);
	}
}

/* SPECIFIC CONTENTS WITHIN EACH COLUMN */

.cover-img {
	display: block;
	width: 100%;
	height: auto;
	border: 1px solid var(--color-neutral-200);
}

.text-area {
	display: flex;
	flex-direction: column;
}

.text-area .links-section {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* PLAYLIST LINKS LIST */

.p-playlist-item-list {
	display: flex;
	flex-direction: column;
}

.p-playlist-item {
	display: flex;
	border-top: 1px solid var(--color-neutral-400);
	align-items: center;
	justify-content: space-between;
	padding: 16px 0;
	gap: 16px;
	flex-wrap: wrap;
}

.p-playlist-item:first-child {
	border: none;
}

.p-playlist-item-text {
	margin-left: 8px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.p-playlist-item-title {
	font-weight: 600;
	color: var(--colour-text-black);
}

.p-playlist-item-date {
	color: var(--colour-text-gray);
	font-size: 0.875rem;
}

.p-playlist-item-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
