/* ==========================================================================
   Photos — Uploader, gallery grid, lightbox, featured badge
   ========================================================================== */

/* ── Photo Uploader ─────────────────────────────────────────────────────── */

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

.photo-uploader-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sc-space-sm);
}

@media (min-width: 640px) {
	.photo-uploader-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.photo-uploader-thumb {
	position: relative;
	aspect-ratio: 1;
	border-radius: var(--sc-radius-md);
	overflow: hidden;
	border: var(--sc-border-width) solid var(--sc-border-subtle);
}

.photo-uploader-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.photo-uploader-remove {
	position: absolute;
	top: var(--sc-space-xs);
	right: var(--sc-space-xs);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.5rem;
	height: 1.5rem;
	border-radius: var(--sc-radius-full);
	background-color: var(--sc-error);
	color: var(--sc-text-inverse);
	border: none;
	cursor: pointer;
	font-size: var(--sc-text-xs);
	line-height: 1;
	padding: 0;
	transition: transform var(--sc-transition-fast) var(--sc-ease-default);
}

.photo-uploader-remove:hover {
	transform: scale(1.15);
}

.photo-uploader-add {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--sc-space-xs);
	aspect-ratio: 1;
	border: 2px dashed var(--sc-border);
	border-radius: var(--sc-radius-md);
	background-color: var(--sc-bg);
	color: var(--sc-text-tertiary);
	cursor: pointer;
	font-size: var(--sc-text-2xl);
	transition: border-color var(--sc-transition-fast) var(--sc-ease-default),
		color var(--sc-transition-fast) var(--sc-ease-default);
}

.photo-uploader-add:hover {
	border-color: var(--sc-accent);
	color: var(--sc-accent);
}

.photo-uploader-add-icon {
	width: 1.5rem;
	height: 1.5rem;
}

.photo-uploader-add-label {
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
}

.photo-uploader-add--camera {
	border-style: dashed;
}

.photo-uploader-count {
	font-size: var(--sc-text-sm);
	color: var(--sc-text-tertiary);
}

.photo-uploader-input {
	display: none;
}

/* ── Contribute Photo Grid (method cards stay separate, grid below) ──── */

.contribute-photo-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sc-space-sm);
	margin-top: var(--sc-space-lg);
}

@media (min-width: 640px) {
	.contribute-photo-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ── Photo Gallery (thumbnail grid) ─────────────────────────────────────── */

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

.photo-gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--sc-space-sm);
}

@media (min-width: 640px) {
	.photo-gallery-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 1024px) {
	.photo-gallery-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.photo-gallery-item-wrapper {
	position: relative;
}

.photo-gallery-item {
	position: relative;
	width: 100%;
	aspect-ratio: 1;
	border-radius: var(--sc-radius-md);
	overflow: hidden;
	cursor: pointer;
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	transition: box-shadow var(--sc-transition-fast) var(--sc-ease-default),
		transform var(--sc-transition-fast) var(--sc-ease-default);
}

.photo-gallery-item:hover {
	box-shadow: var(--sc-shadow-md);
	transform: translateY(-1px);
}

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

.photo-gallery-featured-badge {
	position: absolute;
	top: var(--sc-space-xs);
	left: var(--sc-space-xs);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: var(--sc-radius-full);
	background-color: var(--sc-accent);
	color: var(--sc-text-inverse);
	font-size: var(--sc-text-sm);
	box-shadow: var(--sc-shadow-sm);
}

.photo-gallery-star-btn {
	position: absolute;
	top: var(--sc-space-xs);
	right: var(--sc-space-xs);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: var(--sc-radius-full);
	background-color: rgba(45, 41, 38, 0.5);
	color: var(--sc-text-inverse);
	border: none;
	cursor: pointer;
	font-size: var(--sc-text-sm);
	opacity: 0;
	transition: opacity var(--sc-transition-fast) var(--sc-ease-default),
		background-color var(--sc-transition-fast) var(--sc-ease-default);
}

.photo-gallery-item-wrapper:hover .photo-gallery-star-btn {
	opacity: 1;
}

.photo-gallery-star-btn:hover {
	background-color: var(--sc-accent);
}

.photo-gallery-star-btn[data-featured='true'] {
	opacity: 1;
	background-color: var(--sc-accent);
}

/* ==========================================================================
   Lightbox — Cinematic photo viewer with tagging
   ========================================================================== */

.lb-overlay {
	position: fixed;
	inset: 0;
	z-index: var(--sc-z-modal);
	display: flex;
	flex-direction: column;
	background: linear-gradient(180deg, rgba(18, 16, 14, 0.97) 0%, rgba(28, 24, 20, 0.98) 100%);
	animation: lb-enter var(--sc-transition-normal) var(--sc-ease-out);
}

@keyframes lb-enter {
	from { opacity: 0; }
	to { opacity: 1; }
}

/* ── Header bar ────────────────────────────────────────────────────────── */

.lb-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sc-space-sm) var(--sc-space-md);
	position: relative;
	z-index: 3;
	flex-shrink: 0;
}

.lb-header-left,
.lb-header-right {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	min-width: 6rem;
}

.lb-header-right {
	justify-content: flex-end;
}

.lb-header-center {
	display: flex;
	align-items: center;
	justify-content: center;
}

.lb-header--minimal .lb-header-left {
	flex: 1;
	min-width: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 var(--sc-space-sm);
}

.lb-header--minimal .lb-header-right {
	min-width: 2.5rem;
}

.lb-header-hint {
	margin: 0;
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	color: rgba(255, 255, 255, 0.75);
	text-align: center;
}

.lb-counter {
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	color: rgba(255, 255, 255, 0.5);
	letter-spacing: var(--sc-tracking-wide);
}

/* ── Buttons ───────────────────────────────────────────────────────────── */

.lb-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	padding: var(--sc-space-sm) var(--sc-space-md);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--sc-radius-full);
	background: rgba(255, 255, 255, 0.06);
	color: rgba(255, 255, 255, 0.8);
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	cursor: pointer;
	transition: all var(--sc-transition-fast) var(--sc-ease-default);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}

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

.lb-btn:hover {
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.25);
	color: rgba(255, 255, 255, 1);
}

.lb-btn-tag--active {
	background: var(--sc-accent);
	border-color: var(--sc-accent);
	color: rgba(255, 255, 255, 1);
}

.lb-btn-tag--active:hover {
	background: var(--sc-accent-hover);
	border-color: var(--sc-accent-hover);
}

.lb-btn-close {
	width: 2.5rem;
	height: 2.5rem;
	padding: 0;
	justify-content: center;
	border-radius: var(--sc-radius-full);
}

.lb-btn-close svg {
	width: 1.25rem;
	height: 1.25rem;
}

/* ── Stage (photo area) ────────────────────────────────────────────────── */

.lb-stage {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 var(--sc-space-3xl);
	min-height: 0;
	position: relative;
}

@media (max-width: 639px) {
	.lb-stage {
		padding: 0 var(--sc-space-md);
	}
}

.lb-photo-frame {
	position: relative;
	display: inline-flex;
	max-width: 100%;
	max-height: 100%;
	border-radius: var(--sc-radius-md);
	overflow: visible;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5), 0 4px 16px rgba(0, 0, 0, 0.3);
}

.lb-pins-layer {
	position: absolute;
	inset: 0;
	pointer-events: none;
	border-radius: var(--sc-radius-md);
}

.lb-pins-layer .lb-pin {
	pointer-events: auto;
}

.lb-pins-layer--hidden {
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
}

.lb-photo-frame--tagging {
	cursor: crosshair;
}

.lb-photo {
	display: block;
	max-width: 88vw;
	max-height: min(68vh, 720px);
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: var(--sc-radius-md);
	user-select: none;
	opacity: 0;
	transition: opacity var(--sc-transition-normal) var(--sc-ease-default);
}

.lb-photo--loaded {
	opacity: 1;
}

/* ── Face pins ─────────────────────────────────────────────────────────── */

.lb-pin {
	position: absolute;
	transform: translate(-50%, -50%);
	width: 0.9rem;
	height: 0.9rem;
	border-radius: var(--sc-radius-full);
	background: radial-gradient(circle, rgba(193, 122, 58, 0.3) 0%, rgba(193, 122, 58, 0.5) 100%);
	border: 1.5px solid rgba(255, 255, 255, 0.6);
	cursor: pointer;
	z-index: 1;
	transition: transform var(--sc-transition-fast) var(--sc-ease-default),
		background var(--sc-transition-fast) var(--sc-ease-default),
		border-color var(--sc-transition-fast) var(--sc-ease-default),
		box-shadow var(--sc-transition-fast) var(--sc-ease-default);
}

.lb-pin:hover {
	transform: translate(-50%, -50%) scale(1.25);
	box-shadow: 0 0 0 4px rgba(193, 122, 58, 0.25);
}

.lb-pin--uncertain {
	border-style: dashed;
	background: radial-gradient(circle, rgba(184, 134, 58, 0.7) 0%, rgba(184, 134, 58, 0.5) 100%);
}

.lb-pin--pending {
	background: radial-gradient(circle, rgba(255, 255, 255, 0.5) 0%, rgba(255, 255, 255, 0.3) 100%);
	border-color: var(--sc-accent);
	animation: lb-pin-pulse 1.5s ease-in-out infinite;
}

@keyframes lb-pin-pulse {
	0%, 100% { transform: translate(-50%, -50%) scale(1); box-shadow: 0 0 0 0 rgba(193, 122, 58, 0.4); }
	50% { transform: translate(-50%, -50%) scale(1.2); box-shadow: 0 0 0 8px rgba(193, 122, 58, 0); }
}

.lb-pin--highlighted {
	transform: translate(-50%, -50%) scale(1.3);
	background: var(--sc-accent);
	border-color: rgba(255, 255, 255, 1);
	box-shadow: 0 0 0 5px rgba(193, 122, 58, 0.35), 0 0 20px rgba(193, 122, 58, 0.2);
	z-index: 2;
}

/* ── Pin label tooltip ─────────────────────────────────────────────────── */

.lb-pin-label {
	position: absolute;
	bottom: calc(100% + 6px);
	left: 50%;
	transform: translateX(-50%);
	white-space: nowrap;
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	color: rgba(255, 255, 255, 0.95);
	background: rgba(28, 24, 20, 0.9);
	padding: 3px var(--sc-space-sm);
	border-radius: var(--sc-radius-sm);
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--sc-transition-fast) var(--sc-ease-default);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.lb-pin:hover .lb-pin-label,
.lb-pin--highlighted .lb-pin-label {
	opacity: 1;
}

.lb-pin-label--pending {
	opacity: 1;
	background: var(--sc-accent);
	font-weight: var(--sc-weight-bold);
}

/* ── Bottom dock — caption rail + centered toolbar ────────────────────── */

.lb-dock {
	flex-shrink: 0;
	align-self: center;
	width: 100%;
	max-width: min(40rem, calc(100vw - var(--sc-space-md) * 2));
	margin: 0 var(--sc-space-md) var(--sc-space-md);
	padding: 0;
	z-index: 3;
}

.lb-dock__inner {
	border-radius: var(--sc-radius-xl);
	background: linear-gradient(
		165deg,
		rgba(32, 28, 24, 0.92) 0%,
		rgba(18, 16, 14, 0.94) 100%
	);
	border: 1px solid rgba(255, 255, 255, 0.09);
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.06) inset,
		0 16px 48px rgba(0, 0, 0, 0.55);
	backdrop-filter: blur(16px) saturate(1.15);
	-webkit-backdrop-filter: blur(16px) saturate(1.15);
	padding: var(--sc-space-md) var(--sc-space-lg) var(--sc-space-md);
}

.lb-dock__caption-panel {
	margin-bottom: 0;
}

.lb-dock__caption-view {
	display: grid;
	grid-template-columns: minmax(2.75rem, auto) minmax(0, 1fr) auto;
	align-items: center;
	gap: var(--sc-space-md) var(--sc-space-lg);
}

/* Single-photo: caption + edit only (no counter column) */
.lb-dock__caption-view--solo {
	grid-template-columns: minmax(0, 1fr) auto;
}

.lb-dock__caption-meta {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	padding-top: 0.15rem;
}

.lb-dock__counter-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.75rem;
	padding: 0.2rem 0.5rem;
	border-radius: var(--sc-radius-full);
	font-family: var(--sc-font-ui);
	font-size: 0.68rem;
	font-weight: var(--sc-weight-semibold);
	letter-spacing: 0.04em;
	color: rgba(255, 255, 255, 0.55);
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.lb-dock__caption-center {
	min-width: 0;
	text-align: left;
}

.lb-dock__quote {
	margin: 0;
	font-family: var(--sc-font-display);
	font-size: clamp(0.95rem, 2.2vw, 1.08rem);
	font-weight: 400;
	line-height: 1.55;
	color: rgba(255, 252, 248, 0.94);
	padding-left: var(--sc-space-md);
	border-left: 2px solid color-mix(in srgb, var(--sc-rust-soft) 75%, transparent);
	text-wrap: balance;
}

.lb-dock__quote-placeholder {
	margin: 0;
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.38);
	font-style: italic;
	padding-left: var(--sc-space-md);
	border-left: 2px solid rgba(255, 255, 255, 0.12);
}

.lb-dock__caption-tools {
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
	padding-top: 0.05rem;
}

.lb-dock__edit-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.95rem;
	height: 1.95rem;
	border-radius: var(--sc-radius-full);
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: rgba(255, 255, 255, 0.72);
	cursor: pointer;
	transition:
		background var(--sc-transition-fast) var(--sc-ease-default),
		border-color var(--sc-transition-fast) var(--sc-ease-default),
		color var(--sc-transition-fast) var(--sc-ease-default),
		transform var(--sc-transition-fast) var(--sc-ease-default);
}

.lb-dock__edit-btn:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.2);
	color: rgba(255, 255, 255, 1);
	transform: scale(1.04);
}

.lb-dock__edit-btn svg {
	width: 0.95rem;
	height: 0.95rem;
}

.lb-dock__caption-edit {
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-sm);
}

.lb-dock__caption-input {
	width: 100%;
	box-sizing: border-box;
	padding: var(--sc-space-sm) var(--sc-space-md);
	border-radius: var(--sc-radius-md);
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(0, 0, 0, 0.4);
	color: rgba(255, 255, 255, 0.96);
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	line-height: 1.45;
	resize: vertical;
	min-height: 3.25rem;
}

.lb-dock__caption-input::placeholder {
	color: rgba(255, 255, 255, 0.35);
}

.lb-dock__caption-input:focus {
	outline: none;
	border-color: color-mix(in srgb, var(--sc-rust-soft) 55%, transparent);
	box-shadow: 0 0 0 2px rgba(193, 122, 58, 0.2);
}

.lb-dock__caption-actions {
	display: flex;
	justify-content: flex-end;
	gap: var(--sc-space-sm);
}

.lb-dock__link-btn {
	background: none;
	border: none;
	color: rgba(255, 255, 255, 0.5);
	font-size: var(--sc-text-sm);
	cursor: pointer;
	padding: var(--sc-space-xs) var(--sc-space-sm);
	font-family: var(--sc-font-body);
}

.lb-dock__link-btn:hover {
	color: rgba(255, 255, 255, 0.88);
}

.lb-dock__primary-btn {
	padding: 0.4rem var(--sc-space-md);
	border-radius: var(--sc-radius-full);
	border: none;
	background: var(--sc-accent);
	color: rgba(255, 255, 255, 0.98);
	font-size: var(--sc-text-sm);
	font-weight: var(--sc-weight-medium);
	font-family: var(--sc-font-body);
	cursor: pointer;
}

.lb-dock__primary-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.lb-dock__rule {
	height: 1px;
	margin: var(--sc-space-md) 0 var(--sc-space-md);
	background: linear-gradient(
		90deg,
		transparent 0%,
		rgba(255, 255, 255, 0.1) 20%,
		rgba(255, 255, 255, 0.1) 80%,
		transparent 100%
	);
}

.lb-dock__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	width: 100%;
}

.lb-dock__tool {
	--lb-tool-border: rgba(255, 255, 255, 0.12);
	--lb-tool-bg: rgba(255, 255, 255, 0.04);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	min-height: 2.35rem;
	padding: 0 0.95rem;
	border-radius: var(--sc-radius-full);
	border: 1px solid var(--lb-tool-border);
	background: var(--lb-tool-bg);
	color: rgba(255, 255, 255, 0.88);
	font-family: var(--sc-font-ui);
	font-size: 0.72rem;
	font-weight: var(--sc-weight-semibold);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	cursor: pointer;
	transition:
		background var(--sc-transition-fast) var(--sc-ease-default),
		border-color var(--sc-transition-fast) var(--sc-ease-default),
		color var(--sc-transition-fast) var(--sc-ease-default),
		box-shadow var(--sc-transition-fast) var(--sc-ease-default);
}

.lb-dock__tool svg {
	width: 0.9rem;
	height: 0.9rem;
	flex-shrink: 0;
	opacity: 0.9;
}

.lb-dock__tool-label {
	line-height: 1;
}

.lb-dock__tool:hover {
	--lb-tool-border: rgba(255, 255, 255, 0.2);
	--lb-tool-bg: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 1);
}

.lb-dock__tool--pressed {
	--lb-tool-border: color-mix(in srgb, var(--sc-rust-soft) 55%, rgba(255, 255, 255, 0.1));
	--lb-tool-bg: color-mix(in srgb, var(--sc-rust-soft) 22%, rgba(0, 0, 0, 0.2));
	color: rgba(255, 252, 248, 0.98);
	box-shadow: 0 0 0 1px rgba(193, 122, 58, 0.15);
}

.lb-dock__tool--primary {
	--lb-tool-border: color-mix(in srgb, var(--sc-rust-soft) 65%, transparent);
	--lb-tool-bg: color-mix(in srgb, var(--sc-rust-soft) 28%, rgba(0, 0, 0, 0.15));
	color: rgba(255, 252, 248, 1);
}

.lb-dock__tool--primary:hover {
	--lb-tool-bg: color-mix(in srgb, var(--sc-rust-soft) 38%, rgba(0, 0, 0, 0.12));
	--lb-tool-border: color-mix(in srgb, var(--sc-rust-soft) 80%, transparent);
}

.lb-dock__tool--wide {
	min-width: min(100%, 14rem);
	text-transform: none;
	font-size: var(--sc-text-sm);
	letter-spacing: 0;
	font-weight: var(--sc-weight-medium);
	font-family: var(--sc-font-body);
}

.lb-dock__tool-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.2rem;
	height: 1.2rem;
	padding: 0 5px;
	margin-left: 1px;
	border-radius: var(--sc-radius-full);
	background: rgba(0, 0, 0, 0.45);
	border: 1px solid rgba(255, 255, 255, 0.12);
	font-size: 0.62rem;
	font-weight: var(--sc-weight-bold);
	letter-spacing: 0;
	color: rgba(255, 255, 255, 0.92);
}

.lb-dock__tool--primary .lb-dock__tool-badge {
	background: rgba(0, 0, 0, 0.35);
	border-color: rgba(255, 255, 255, 0.15);
}

@media (max-width: 479px) {
	.lb-dock__caption-view {
		grid-template-columns: 1fr;
		gap: var(--sc-space-sm);
	}

	.lb-dock__caption-meta {
		order: 0;
	}

	.lb-dock__caption-tools {
		order: 1;
		justify-content: flex-start;
	}

	.lb-dock__caption-center {
		order: 2;
	}

	.lb-dock__toolbar {
		gap: 0.4rem;
	}

	.lb-dock__tool {
		padding: 0 0.75rem;
		font-size: 0.65rem;
	}
}

/* ── Tag picker — centered so search results stay in viewport ─────────── */

.lb-picker {
	background: rgba(250, 247, 242, 0.98);
	border-radius: var(--sc-radius-xl);
	padding: var(--sc-space-md) var(--sc-space-lg);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.12);
	z-index: 20;
	display: flex;
	flex-direction: column;
	max-height: min(85vh, 32rem);
}

.lb-picker--center {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: min(22rem, calc(100vw - var(--sc-space-lg) * 2));
	animation: lb-picker-fade var(--sc-transition-normal) var(--sc-ease-out);
}

@keyframes lb-picker-fade {
	from { opacity: 0; transform: translate(-50%, -50%) scale(0.98); }
	to { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

.lb-picker-body {
	flex: 1;
	min-height: 0;
	display: flex;
	flex-direction: column;
	margin-top: var(--sc-space-xs);
}

/* Stack search results inside picker (no absolute dropdown off-screen) */
.lb-picker-body .person-search-wrap {
	display: flex;
	flex-direction: column;
	flex: 1;
	min-height: 0;
}

.lb-picker-body .person-search-results {
	position: relative;
	top: auto;
	left: auto;
	right: auto;
	margin-top: var(--sc-space-xs);
	flex: 1;
	min-height: 8rem;
	max-height: min(42vh, 16rem);
	overflow-y: auto;
}

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

.lb-picker-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;
}

.lb-picker-cancel {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: var(--sc-radius-full);
	background: transparent;
	border: none;
	cursor: pointer;
	color: var(--sc-text-tertiary);
	transition: color var(--sc-transition-fast), background var(--sc-transition-fast);
}

.lb-picker-cancel svg {
	width: 1rem;
	height: 1rem;
}

.lb-picker-cancel:hover {
	background: var(--sc-bg);
	color: var(--sc-text-primary);
}

.lb-picker-uncertain {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	margin-top: var(--sc-space-sm);
	cursor: pointer;
}

.lb-picker-uncertain input[type="checkbox"] {
	accent-color: var(--sc-accent);
}

/* ── People strip (tagged characters) ──────────────────────────────────── */

.lb-people {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--sc-space-xs);
	padding: var(--sc-space-sm) var(--sc-space-lg) var(--sc-space-md);
	position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
	z-index: 5;
	flex-shrink: 0;
}

.lb-person-chip {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	padding: var(--sc-space-xs) var(--sc-space-sm) var(--sc-space-xs) var(--sc-space-md);
	border-radius: var(--sc-radius-full);
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.1);
	transition: all var(--sc-transition-fast) var(--sc-ease-default);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.lb-person-chip:hover {
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.2);
}

.lb-person-chip--uncertain {
	border-style: dashed;
	border-color: rgba(255, 255, 255, 0.25);
}

.lb-person-chip--highlighted {
	background: rgba(193, 122, 58, 0.35);
	border-color: rgba(193, 122, 58, 0.6);
	box-shadow: 0 0 12px rgba(193, 122, 58, 0.15);
}

.lb-person-chip-name {
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-medium);
	color: rgba(255, 255, 255, 0.85);
}

.lb-person-chip-confirm,
.lb-person-chip-remove {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.125rem;
	height: 1.125rem;
	border-radius: var(--sc-radius-full);
	border: none;
	cursor: pointer;
	padding: 0;
	margin-left: 2px;
	transition: all var(--sc-transition-fast);
}

.lb-person-chip-confirm svg,
.lb-person-chip-remove svg {
	width: 0.625rem;
	height: 0.625rem;
}

.lb-person-chip-confirm {
	background: var(--sc-success);
	color: rgba(255, 255, 255, 0.95);
}

.lb-person-chip-confirm:hover {
	background: color-mix(in srgb, var(--sc-success) 80%, white);
	transform: scale(1.1);
}

.lb-person-chip-remove {
	background: transparent;
	color: rgba(255, 255, 255, 0.4);
}

.lb-person-chip-remove:hover {
	background: rgba(192, 80, 58, 0.6);
	color: rgba(255, 255, 255, 0.95);
	transform: scale(1.1);
}

.lb-person-chip-remove:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

/* ── Navigation arrows ─────────────────────────────────────────────────── */

.lb-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: var(--sc-radius-full);
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.6);
	cursor: pointer;
	z-index: 3;
	transition: all var(--sc-transition-fast) var(--sc-ease-default);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

.lb-nav svg {
	width: 1.25rem;
	height: 1.25rem;
}

.lb-nav:hover {
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.2);
	color: rgba(255, 255, 255, 1);
}

.lb-nav--prev {
	left: var(--sc-space-md);
}

.lb-nav--next {
	right: var(--sc-space-md);
}

@media (max-width: 639px) {
	.lb-nav {
		width: 2.5rem;
		height: 2.5rem;
	}

	.lb-nav--prev {
		left: var(--sc-space-xs);
	}

	.lb-nav--next {
		right: var(--sc-space-xs);
	}
}

/* ── Reduced motion ────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
	.lb-overlay {
		animation: none;
	}

	.lb-picker--center {
		animation: none;
	}

	.lb-pin--pending {
		animation: none;
	}
}
