/* ==========================================================================
   Media — Memory timeline, archive cards, memory detail layout
   ========================================================================== */

/* ── Memory Timeline (all segments visible) ────────────────────────────── */

.memory-timeline {
	display: flex;
	flex-direction: column;
}

.timeline-segment {
	display: flex;
	gap: var(--sc-space-md);
	min-height: 4rem;
}

.timeline-segment-marker {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex-shrink: 0;
	width: 1.5rem;
	padding-top: var(--sc-space-sm);
}

.timeline-dot {
	width: 0.625rem;
	height: 0.625rem;
	border-radius: var(--sc-radius-full);
	background: var(--sc-border);
	flex-shrink: 0;
}

.timeline-dot[data-type='audio'] {
	background: var(--sc-accent);
}

.timeline-dot[data-type='video'] {
	background: var(--sc-success);
}

.timeline-dot[data-type='text'] {
	background: var(--sc-text-secondary);
}

.timeline-line {
	width: 2px;
	flex: 1;
	background: var(--sc-border-subtle);
	margin: var(--sc-space-xs) 0;
}

.timeline-segment-content {
	flex: 1;
	min-width: 0;
	padding-bottom: var(--sc-space-lg);
}

.timeline-segment-header {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	margin-bottom: var(--sc-space-sm);
}

.timeline-segment-label {
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-text-tertiary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.timeline-segment-duration {
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	font-variant-numeric: tabular-nums;
}

/* Audio in timeline */
.timeline-audio {
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: var(--sc-radius-md);
	padding: var(--sc-space-sm) var(--sc-space-md);
}

.timeline-audio audio {
	width: 100%;
	height: 2.5rem;
}

/* Video in timeline */
.timeline-video {
	border-radius: var(--sc-radius-lg);
	overflow: hidden;
	box-shadow: var(--sc-shadow-sm);
}

.timeline-video video {
	width: 100%;
	display: block;
	max-height: 20rem;
	background: var(--sc-text-primary);
}

/* Text in timeline */
.timeline-text {
	position: relative;
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: var(--sc-radius-md);
	padding: var(--sc-space-md) var(--sc-space-lg);
}

.timeline-text-content {
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	line-height: var(--sc-leading-relaxed);
	color: var(--sc-text-primary);
	margin: 0;
}

.timeline-text-content p {
	margin: 0 0 var(--sc-space-sm);
}

.timeline-text-content p:last-child {
	margin-bottom: 0;
}

.timeline-text-content ul,
.timeline-text-content ol {
	padding-left: var(--sc-space-lg);
	margin: 0 0 var(--sc-space-sm);
}

.timeline-text-content ul {
	list-style-type: disc;
}

.timeline-text-content ol {
	list-style-type: decimal;
}

.timeline-text-content li {
	margin-bottom: var(--sc-space-xs);
}

.timeline-text-content strong {
	font-weight: var(--sc-weight-semibold);
}

.timeline-text-content em {
	font-style: italic;
}

.timeline-text-edit-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	border: none;
	background: none;
	color: var(--sc-text-tertiary);
	font-size: var(--sc-text-xs);
	cursor: pointer;
	padding: var(--sc-space-xs) 0;
	margin-top: var(--sc-space-sm);
	transition: color var(--sc-transition-fast) var(--sc-ease-default);
}

.timeline-text-edit-btn:hover {
	color: var(--sc-accent);
}

/* Text editing */
.timeline-text-edit {
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-accent);
	border-radius: var(--sc-radius-md);
	padding: var(--sc-space-md);
}

.timeline-text-edit-input {
	width: 100%;
	min-height: 6rem;
	padding: var(--sc-space-sm);
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	line-height: var(--sc-leading-normal);
	color: var(--sc-text-primary);
	background: transparent;
	border: none;
	resize: vertical;
}

.timeline-text-edit-input:focus {
	outline: none;
}

.timeline-text-edit-actions {
	display: flex;
	gap: var(--sc-space-sm);
	margin-top: var(--sc-space-sm);
}

/* Uploading state */
.timeline-uploading {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-md) var(--sc-space-lg);
	background: var(--sc-warning-subtle);
	border-radius: var(--sc-radius-md);
	font-size: var(--sc-text-sm);
	color: var(--sc-warning);
}

.timeline-uploading-dot {
	width: 0.5rem;
	height: 0.5rem;
	border-radius: var(--sc-radius-full);
	background: var(--sc-warning);
	animation: recording-pulse 1.5s ease-in-out infinite;
}

/* ── Memory Detail Page ────────────────────────────────────────────────── */

.memory-detail {
	max-width: var(--sc-width-content);
	margin: 0 auto;
}

.memory-detail-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--sc-space-lg);
}

.memory-detail-nav-actions {
	display: flex;
	gap: var(--sc-space-sm);
}

.memory-detail-back {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	text-decoration: none;
	transition: color var(--sc-transition-fast) var(--sc-ease-default);
}

.memory-detail-back:hover {
	color: var(--sc-accent);
}

/* ── Sharing / Visibility ───────────────────────────────────────────────── */

.sharing-options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sc-space-sm);
}

.sharing-option {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--sc-space-xs);
	padding: var(--sc-space-md) var(--sc-space-sm);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	cursor: pointer;
	transition: border-color var(--sc-transition-fast),
	            background var(--sc-transition-fast);
}

.sharing-option input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.sharing-option:hover {
	border-color: var(--sc-border);
	background: var(--sc-surface);
}

.sharing-option--active {
	border-color: var(--sc-accent);
	background: var(--sc-accent-subtle);
}

.sharing-option-icon {
	width: 1.5rem;
	height: 1.5rem;
	color: var(--sc-text-tertiary);
	transition: color var(--sc-transition-fast);
}

.sharing-option--active .sharing-option-icon {
	color: var(--sc-accent);
}

.sharing-option-label {
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
}

.sharing-option-desc {
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	line-height: var(--sc-leading-normal);
}

.sharing-level-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	margin-top: var(--sc-space-sm);
}

.sharing-level-select {
	width: auto;
	min-width: 8rem;
	font-size: var(--sc-text-sm);
	padding: var(--sc-space-xs) var(--sc-space-sm);
	min-height: 2rem;
}

.sharing-people-list {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-xs);
}

.sharing-person {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-xs) var(--sc-space-sm);
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
}

.sharing-person-name {
	flex: 1;
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
}

.sharing-add-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	flex-wrap: wrap;
	margin-top: var(--sc-space-sm);
}

.sharing-add-row .form-input {
	width: auto;
	min-width: 10rem;
}

@media (max-width: 639px) {
	.sharing-add-row {
		flex-direction: column;
		align-items: stretch;
	}

	.memory-permissions-add-row .form-input {
		width: 100%;
	}

	.memory-permissions-item {
		flex-wrap: wrap;
	}
}

.memory-detail-header--editing {
	margin-bottom: var(--sc-space-lg);
	padding: var(--sc-space-lg);
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
}

.memory-detail-header--editing .form-group {
	margin-bottom: var(--sc-space-md);
}

.memory-detail-edit-actions {
	display: flex;
	gap: var(--sc-space-md);
	padding: var(--sc-space-md) 0;
	margin-bottom: var(--sc-space-xl);
}

.memory-detail-header {
	margin-bottom: var(--sc-space-xl);
	padding-bottom: var(--sc-space-lg);
	border-bottom: var(--sc-border-width) solid var(--sc-border);
}

.memory-detail-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-2xl);
	font-weight: var(--sc-weight-bold);
	color: var(--sc-text-primary);
	line-height: var(--sc-leading-tight);
	margin: 0 0 var(--sc-space-sm);
}

.memory-detail-byline {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--sc-space-sm);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
}

.memory-detail-author {
	font-weight: var(--sc-weight-medium);
}

.memory-detail-separator {
	color: var(--sc-text-tertiary);
}

.memory-detail-date {
	color: var(--sc-text-tertiary);
}

.memory-detail-tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sc-space-xs);
	margin-top: var(--sc-space-md);
}

.memory-tag {
	display: inline-flex;
	align-items: center;
	padding: var(--sc-space-xs) var(--sc-space-sm);
	background: var(--sc-accent-subtle);
	color: var(--sc-accent-text);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	border-radius: var(--sc-radius-full);
}

.memory-detail-status {
	margin-top: var(--sc-space-md);
}

.memory-detail-segments {
	margin-bottom: var(--sc-space-xl);
}

.memory-detail-section-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-lg);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
	margin: 0 0 var(--sc-space-md);
}

.memory-detail-contributions {
	padding-top: var(--sc-space-lg);
	border-top: var(--sc-border-width) solid var(--sc-border);
	margin-bottom: var(--sc-space-lg);
}

.memory-detail-footer {
	display: flex;
	gap: var(--sc-space-md);
	padding-top: var(--sc-space-lg);
	border-top: var(--sc-border-width) solid var(--sc-border);
}

/* ── Upload Status Badge ──────────────────────────────────────────────── */

.upload-status {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	padding: var(--sc-space-xs) var(--sc-space-sm);
	border-radius: var(--sc-radius-full);
}

.upload-status-pending,
.upload-status-uploading {
	background: var(--sc-warning-subtle);
	color: var(--sc-warning);
}

.upload-status-complete {
	background: var(--sc-success-subtle);
	color: var(--sc-success);
}

.upload-status-failed {
	background: var(--sc-error-subtle);
	color: var(--sc-error);
}

.upload-status-dot {
	width: 0.375rem;
	height: 0.375rem;
	border-radius: var(--sc-radius-full);
	background: currentColor;
	animation: recording-pulse 1.5s ease-in-out infinite;
}

/* ── Archive Page ──────────────────────────────────────────────────────── */

.archive-page {
	max-width: var(--sc-width-wide);
	margin: 0 auto;
}

.archive-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: var(--sc-space-xl);
}

.archive-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-2xl);
	font-weight: var(--sc-weight-bold);
	color: var(--sc-text-primary);
	margin: 0;
}

/* Archive empty state */
.archive-empty {
	text-align: center;
	padding: var(--sc-space-3xl) var(--sc-space-lg);
}

.archive-empty-illustration {
	margin-bottom: var(--sc-space-lg);
	opacity: 0.7;
}

.archive-empty-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-xl);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
	margin: 0 0 var(--sc-space-sm);
}

.archive-empty-text {
	font-size: var(--sc-text-base);
	color: var(--sc-text-secondary);
	max-width: 24rem;
	margin: 0 auto var(--sc-space-xl);
	line-height: var(--sc-leading-normal);
}

/* Memory cards — responsive grid */
.memory-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sc-space-md);
}

@media (min-width: 640px) {
	.memory-cards {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.memory-cards {
		grid-template-columns: repeat(3, 1fr);
	}
}

.memory-card {
	display: block;
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: var(--sc-radius-lg);
	box-shadow: var(--sc-shadow-sm);
	text-decoration: none;
	color: var(--sc-text-primary);
	overflow: hidden;
	transition: box-shadow var(--sc-transition-normal) var(--sc-ease-default),
		border-color var(--sc-transition-normal) var(--sc-ease-default),
		transform var(--sc-transition-normal) var(--sc-ease-default);
}

.memory-card:hover,
.memory-card:focus-visible {
	box-shadow: var(--sc-shadow-md);
	border-color: var(--sc-accent);
	transform: translateY(-1px);
}

.memory-card:focus-visible {
	outline: none;
	box-shadow: var(--sc-focus-ring);
}

/* Uploading state for memory cards */
.memory-card--uploading {
	opacity: 0.85;
	border-style: dashed;
}

.memory-card-upload-status {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-warning);
}

.memory-card-date-strip {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--sc-space-sm) var(--sc-space-lg);
	background: var(--sc-accent-subtle);
	border-bottom: var(--sc-border-width) solid var(--sc-border);
}

.memory-card-date {
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: var(--sc-accent-text);
	letter-spacing: 0.02em;
}

.memory-card-time {
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.memory-card-body {
	padding: var(--sc-space-md) var(--sc-space-lg) var(--sc-space-lg);
}

.memory-card-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-lg);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
	line-height: var(--sc-leading-tight);
	margin: 0 0 var(--sc-space-sm);
}

.memory-card-excerpt {
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	line-height: var(--sc-leading-normal);
	margin: 0 0 var(--sc-space-md);
	font-style: italic;
}

.memory-card-footer {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sc-space-sm) var(--sc-space-md);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

.memory-card-tags {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sc-space-xs);
	margin-top: var(--sc-space-sm);
}

.memory-card-tag {
	font-size: var(--sc-text-xs);
	padding: 2px var(--sc-space-sm);
	background: var(--sc-accent-subtle);
	color: var(--sc-accent-text);
	border-radius: var(--sc-radius-full);
}

.memory-card-tag-more {
	background: var(--sc-border-subtle);
	color: var(--sc-text-tertiary);
}

/* Memory card thumbnail */
.memory-card-thumbnail {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background-color: var(--sc-bg);
}

.memory-card-thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 20%; /* Bias toward top — keeps faces visible in portraits */
}

.memory-card-description {
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	line-height: var(--sc-leading-normal);
	margin: 0 0 var(--sc-space-md);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Featured image hero on detail page — adaptive for portrait & landscape */
.memory-detail-hero {
	position: relative;
	border-radius: var(--sc-radius-lg);
	overflow: hidden;
	margin-bottom: var(--sc-space-lg);
	box-shadow: var(--sc-shadow-md);
	display: flex;
	align-items: center;
	justify-content: center;
	max-height: 28rem;
	min-height: 12rem;
	background-color: var(--sc-warm-1, var(--sc-surface));
	cursor: pointer;
}

/* Blurred background layer — creates cinematic warm backdrop */
.memory-detail-hero-blur {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: blur(28px) saturate(0.6) brightness(0.95);
	opacity: 0.55;
	transform: scale(1.15);
	pointer-events: none;
}

/* Main hero image — respects original aspect ratio */
.memory-detail-hero-img {
	position: relative;
	max-width: 100%;
	max-height: 28rem;
	object-fit: contain;
	display: block;
	z-index: 1;
}

/* Subtle warm vignette overlay */
.memory-detail-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: var(--sc-radius-lg);
	box-shadow: inset 0 0 3rem rgba(90, 60, 30, 0.08);
	pointer-events: none;
	z-index: 2;
}

/* Memory description on detail page */
.memory-detail-description {
	font-size: var(--sc-text-base);
	color: var(--sc-text-secondary);
	line-height: var(--sc-leading-normal);
	margin-top: var(--sc-space-sm);
	font-style: italic;
}

.archive-load-more {
	text-align: center;
	padding: var(--sc-space-xl) 0;
	grid-column: 1 / -1;
}

/* ── Stories toolbar (search + view toggle) ───────────────────────────── */

.stories-toolbar {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
	margin-bottom: var(--sc-space-xl);
}

.stories-search {
	flex: 1;
	position: relative;
}

.stories-search-icon {
	position: absolute;
	left: var(--sc-space-md);
	top: 50%;
	transform: translateY(-50%);
	width: 1rem;
	height: 1rem;
	color: var(--sc-text-tertiary);
	pointer-events: none;
}

.stories-search-input {
	width: 100%;
	padding: var(--sc-space-sm) var(--sc-space-md) var(--sc-space-sm) 2.5rem;
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	color: var(--sc-text-primary);
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: var(--sc-radius-full);
	min-height: 2.5rem;
	transition: border-color var(--sc-transition-fast) var(--sc-ease-default),
		box-shadow var(--sc-transition-fast) var(--sc-ease-default);
}

.stories-search-input::placeholder {
	color: var(--sc-text-tertiary);
}

.stories-search-input:focus {
	outline: none;
	border-color: var(--sc-accent);
	box-shadow: 0 0 0 3px var(--sc-accent-subtle);
}

.stories-view-toggle {
	display: flex;
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: var(--sc-radius-md);
	overflow: hidden;
}

.stories-view-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border: none;
	background: transparent;
	color: var(--sc-text-tertiary);
	cursor: pointer;
	transition: color var(--sc-transition-fast) var(--sc-ease-default),
		background var(--sc-transition-fast) var(--sc-ease-default);
}

.stories-view-btn svg {
	width: 1rem;
	height: 1rem;
}

.stories-view-btn:hover {
	color: var(--sc-text-primary);
}

.stories-view-btn.active {
	color: var(--sc-accent);
	background: var(--sc-accent-subtle);
}

/* ── Stories list view ────────────────────────────────────────────────── */

.stories-list {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-sm);
}

.stories-list-item {
	display: flex;
	align-items: flex-start;
	gap: var(--sc-space-md);
	padding: var(--sc-space-md) var(--sc-space-lg);
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	text-decoration: none;
	color: inherit;
	transition: box-shadow var(--sc-transition-fast) var(--sc-ease-default),
		border-color var(--sc-transition-fast) var(--sc-ease-default);
}

.stories-list-item:hover {
	box-shadow: var(--sc-shadow-sm);
	border-color: var(--sc-border);
}

.stories-list-item:focus-visible {
	outline: none;
	box-shadow: var(--sc-focus-ring);
}

.stories-list-item--uploading {
	opacity: 0.85;
	border-style: dashed;
}

.stories-list-thumb {
	width: 4.5rem;
	height: 3.5rem;
	border-radius: var(--sc-radius-sm);
	overflow: hidden;
	flex-shrink: 0;
}

.stories-list-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.stories-list-thumb--empty {
	background: linear-gradient(135deg, var(--sc-warm-1), var(--sc-warm-2));
	display: flex;
	align-items: center;
	justify-content: center;
}

.stories-list-thumb--empty svg {
	width: 1.5rem;
	height: 1.5rem;
	color: rgba(45, 41, 38, 0.2);
}

.stories-list-content {
	flex: 1;
	min-width: 0;
}

.stories-list-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-base);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
	margin: 0 0 2px;
	line-height: var(--sc-leading-tight);
}

.stories-list-desc {
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	margin: 0 0 var(--sc-space-xs);
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.stories-list-meta {
	display: flex;
	align-items: center;
	gap: var(--sc-space-xs);
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}

@media (max-width: 639px) {
	.stories-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.stories-view-toggle {
		align-self: flex-end;
	}

	.stories-list-item {
		padding: var(--sc-space-md);
	}
}

/* ── Content Cards (grouped segments by type) ─────────────────────────── */

.memory-content-cards {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-lg);
}

.content-card {
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	overflow: hidden;
	box-shadow: var(--sc-shadow-sm);
}

.content-card-header {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-sm) var(--sc-space-lg);
	background: var(--sc-bg);
	border-bottom: var(--sc-border-width) solid var(--sc-border-subtle);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-secondary);
}

.content-card-header-icon {
	font-size: var(--sc-text-base);
	flex-shrink: 0;
}

.content-card-body {
	padding: var(--sc-space-md) var(--sc-space-lg);
}

/* Audio content card */
.audio-player-item {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-xs);
	padding: var(--sc-space-sm) 0;
}

.audio-player-item + .audio-player-item {
	border-top: var(--sc-border-width) solid var(--sc-border-subtle);
}

.audio-player-item audio {
	width: 100%;
	height: 2.5rem;
}

.audio-player-label {
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
	font-variant-numeric: tabular-nums;
}

/* Video content card */
.video-player-item {
	border-radius: var(--sc-radius-md);
	overflow: hidden;
	box-shadow: var(--sc-shadow-sm);
}

.video-player-item + .video-player-item {
	margin-top: var(--sc-space-md);
}

.video-player-item video {
	width: 100%;
	display: block;
	max-height: 28rem;
	background: var(--sc-text-primary);
}

/* Text content card */
.text-content-combined {
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	line-height: var(--sc-leading-relaxed);
	color: var(--sc-text-primary);
}

.text-content-combined p {
	margin: 0 0 var(--sc-space-sm);
}

.text-content-combined p:last-child {
	margin-bottom: 0;
}

.text-content-segment + .text-content-segment {
	padding-top: var(--sc-space-md);
	margin-top: var(--sc-space-md);
	border-top: var(--sc-border-width) solid var(--sc-border-subtle);
}

/* ── Photo grid on detail page ────────────────────────────────────────── */

.memory-detail-photos {
	margin-bottom: var(--sc-space-xl);
}

.memory-photo-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: var(--sc-space-sm);
}

.memory-photo-item {
	border-radius: var(--sc-radius-md);
	overflow: hidden;
	aspect-ratio: 1;
	box-shadow: var(--sc-shadow-sm);
}

.memory-photo-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* ── Contribution cards ───────────────────────────────────────────────── */

.contribution-card {
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	padding: var(--sc-space-md) var(--sc-space-lg);
	margin-bottom: var(--sc-space-sm);
}

.contribution-text {
	font-size: var(--sc-text-base);
	color: var(--sc-text-primary);
	line-height: var(--sc-leading-normal);
	margin: 0 0 var(--sc-space-sm);
}

.contribution-meta {
	font-size: var(--sc-text-xs);
	color: var(--sc-text-tertiary);
}
