/* ==========================================================================
   Memory Creation Page — Recording, photos, details flow
   ========================================================================== */

/* ── Page wrapper ──────────────────────────────────────────────────────── */

.memory-create {
	max-width: var(--sc-width-content);
	margin-inline: auto;
	padding: var(--sc-space-lg) var(--sc-space-md);
	padding-bottom: 10rem; /* Space for sticky save bar + bottom nav */
}

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

.memory-create-header {
	margin-bottom: var(--sc-space-xl);
}

.memory-create-header--centered {
	text-align: center;
}

.memory-create-header--centered .memory-create-back {
	display: inline-flex;
	margin-bottom: var(--sc-space-sm);
}

.memory-create-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: var(--sc-space-sm) 0 0;
	line-height: var(--sc-leading-tight);
}

.memory-create-tabs--centered {
	justify-content: center;
}

.memory-create-save-bar-inner--centered {
	justify-content: center;
}

/* ── Section tabs ──────────────────────────────────────────────────────── */

.memory-create-tabs {
	display: flex;
	gap: var(--sc-space-xs);
	border-bottom: var(--sc-border-width) solid var(--sc-border);
	margin-bottom: var(--sc-space-xl);
}

.memory-create-tab {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	padding: var(--sc-space-sm) var(--sc-space-md);
	border: none;
	background: transparent;
	color: var(--sc-text-secondary);
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	font-weight: var(--sc-weight-medium);
	cursor: pointer;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color var(--sc-transition-fast) var(--sc-ease-default),
		border-color var(--sc-transition-fast) var(--sc-ease-default);
	min-height: 3rem;
}

.memory-create-tab:hover {
	color: var(--sc-text-primary);
}

.memory-create-tab.active {
	color: var(--sc-accent);
	border-bottom-color: var(--sc-accent);
}

.memory-create-tab:focus-visible {
	outline: none;
	box-shadow: var(--sc-focus-ring);
	border-radius: var(--sc-radius-sm) var(--sc-radius-sm) 0 0;
}

.memory-create-tab-icon {
	width: 1.25rem;
	height: 1.25rem;
	flex-shrink: 0;
}

.memory-create-tab-badge {
	font-size: var(--sc-text-xs);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-inverse);
	background-color: var(--sc-accent);
	border-radius: var(--sc-radius-full);
	min-width: 1.25rem;
	height: 1.25rem;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 var(--sc-space-xs);
}

/* ── Section container ─────────────────────────────────────────────────── */

.memory-create-section {
	animation: mc-fade-in var(--sc-transition-normal) var(--sc-ease-out);
}

@keyframes mc-fade-in {
	from { opacity: 0; transform: translateY(4px); }
	to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
	.memory-create-section { animation: none; }
}

/* ── Add segment prompt ────────────────────────────────────────────────── */

.memory-create-add-segment {
	text-align: center;
	padding: var(--sc-space-xl) 0;
}

.memory-create-prompt {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-lg);
	color: var(--sc-text-secondary);
	margin: 0 0 var(--sc-space-xl);
	line-height: var(--sc-leading-normal);
}

/* ── Scan printed photo button ─────────────────────────────────────────── */

.memory-create-scan-row {
	margin-top: var(--sc-space-xl);
	border-top: var(--sc-border-width) solid var(--sc-border-subtle);
	padding-top: var(--sc-space-xl);
}

.memory-create-scan-btn {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
	width: 100%;
	padding: var(--sc-space-lg);
	background: var(--sc-surface);
	border: var(--sc-border-width) dashed var(--sc-border);
	border-radius: var(--sc-radius-lg);
	cursor: pointer;
	color: var(--sc-text-primary);
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-base);
	font-weight: var(--sc-weight-medium);
	text-align: left;
	transition: border-color var(--sc-transition-fast) var(--sc-ease-default),
		box-shadow var(--sc-transition-fast) var(--sc-ease-default);
}

.memory-create-scan-btn:hover {
	border-color: var(--sc-accent);
	box-shadow: var(--sc-shadow-sm);
}

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

.memory-create-scan-icon {
	width: 2rem;
	height: 2rem;
	color: var(--sc-accent);
	flex-shrink: 0;
}

/* ── Character pills ───────────────────────────────────────────────────── */

.memory-create-character-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sc-space-sm);
	margin-bottom: var(--sc-space-sm);
}

.memory-create-character-pill {
	display: inline-flex;
	align-items: center;
	gap: var(--sc-space-xs);
	padding: var(--sc-space-xs) var(--sc-space-sm);
	background: var(--sc-accent-subtle);
	border-radius: var(--sc-radius-full);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-primary);
}

.memory-create-character-remove {
	border: none;
	background: transparent;
	color: var(--sc-text-tertiary);
	cursor: pointer;
	font-size: var(--sc-text-lg);
	line-height: 1;
	padding: 0 2px;
	border-radius: var(--sc-radius-full);
	transition: color var(--sc-transition-fast) var(--sc-ease-default);
}

.memory-create-character-remove:hover {
	color: var(--sc-error);
}

/* ── Save bar (sticky bottom) ──────────────────────────────────────────── */

.memory-create-save-bar {
	position: fixed;
	bottom: calc(var(--sc-nav-height) + env(safe-area-inset-bottom, 0));
	left: 0;
	right: 0;
	background: var(--sc-surface);
	border-top: var(--sc-border-width) solid var(--sc-border);
	padding: var(--sc-space-sm) var(--sc-space-lg);
	z-index: calc(var(--sc-z-sticky) + 1);
	box-shadow: 0 -2px 8px rgba(45, 41, 38, 0.06);
}

.memory-create-save-bar-inner {
	max-width: var(--sc-width-content);
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: var(--sc-space-md);
}

.memory-create-save-status {
	margin-right: auto;
}

/* ── Flexible date picker ──────────────────────────────────────────────── */

.flex-date {
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-md);
	padding: var(--sc-space-md);
	background: var(--sc-surface);
}

.flex-date-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sc-space-md);
}

.flex-date-toggle-label {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	font-size: var(--sc-text-base);
	color: var(--sc-text-primary);
	cursor: pointer;
}

.flex-date-preview {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-sm);
	color: var(--sc-accent-text);
	font-weight: var(--sc-weight-medium);
}

.flex-date-controls {
	margin-top: var(--sc-space-md);
	padding-top: var(--sc-space-md);
	border-top: var(--sc-border-width) solid var(--sc-border-subtle);
}

.flex-date-precision {
	display: flex;
	gap: var(--sc-space-xs);
	margin-bottom: var(--sc-space-md);
}

.flex-date-precision-btn {
	flex: 1;
	padding: var(--sc-space-xs) var(--sc-space-sm);
	border: var(--sc-border-width) solid var(--sc-border);
	border-radius: var(--sc-radius-sm);
	background: transparent;
	color: var(--sc-text-secondary);
	font-family: var(--sc-font-body);
	font-size: var(--sc-text-sm);
	cursor: pointer;
	transition: all var(--sc-transition-fast) var(--sc-ease-default);
}

.flex-date-precision-btn:hover {
	border-color: var(--sc-accent);
	color: var(--sc-text-primary);
}

.flex-date-precision-btn.active {
	background: var(--sc-accent);
	border-color: var(--sc-accent);
	color: var(--sc-text-inverse);
}

.flex-date-precision-btn:focus-visible {
	outline: none;
	box-shadow: var(--sc-focus-ring);
}

.flex-date-fields {
	animation: mc-fade-in var(--sc-transition-fast) var(--sc-ease-out);
}

.flex-date-row {
	display: flex;
	align-items: flex-end;
	gap: var(--sc-space-md);
}

.flex-date-field {
	flex: 1;
}

.flex-date-field--narrow {
	flex: 0 0 6rem;
}

.flex-date-label {
	display: block;
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	margin-bottom: var(--sc-space-xs);
}

.flex-date-sep {
	font-size: var(--sc-text-xl);
	color: var(--sc-text-tertiary);
	padding-bottom: var(--sc-space-sm);
}

/* ── Printed photo scanner ─────────────────────────────────────────────── */

.scanner-overlay {
	position: fixed;
	inset: 0;
	background: rgba(30, 27, 24, 0.95);
	z-index: var(--sc-z-modal);
	display: flex;
	align-items: center;
	justify-content: center;
}

.scanner-container {
	width: 100%;
	height: 100%;
	max-width: 48rem;
	display: flex;
	flex-direction: column;
	background: var(--sc-bg);
}

.scanner-header {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
	padding: var(--sc-space-md) var(--sc-space-lg);
	border-bottom: var(--sc-border-width) solid var(--sc-border-subtle);
}

.scanner-title {
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-lg);
	font-weight: var(--sc-weight-semibold);
	color: var(--sc-text-primary);
	flex: 1;
}

.scanner-close-btn,
.scanner-switch-btn {
	width: 2.5rem;
	height: 2.5rem;
	border: none;
	background: transparent;
	border-radius: var(--sc-radius-full);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--sc-text-secondary);
	transition: background var(--sc-transition-fast) var(--sc-ease-default);
}

.scanner-close-btn:hover,
.scanner-switch-btn:hover {
	background: var(--sc-accent-subtle);
}

.scanner-close-btn svg,
.scanner-switch-btn svg {
	width: 1.25rem;
	height: 1.25rem;
}

/* ── Scanner viewport ──────────────────────────────────────────────────── */

.scanner-viewport {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: #1a1815;
	position: relative;
}

.scanner-video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.scanner-loading,
.scanner-error {
	text-align: center;
	color: var(--sc-text-secondary);
	padding: var(--sc-space-2xl);
}

.scanner-loading p,
.scanner-error p {
	margin: var(--sc-space-md) 0 0;
}

/* Guide frame overlay */
.scanner-guide {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}

.scanner-guide-frame {
	width: 80%;
	max-width: 24rem;
	aspect-ratio: 4 / 3;
	border: 2px solid rgba(255, 255, 255, 0.4);
	border-radius: var(--sc-radius-md);
}

.scanner-guide-text {
	color: rgba(255, 255, 255, 0.7);
	font-size: var(--sc-text-sm);
	margin-top: var(--sc-space-md);
}

/* Edge adjustment view */
.scanner-adjusting,
.scanner-captured {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.scanner-edge-preview {
	position: relative;
	max-width: 100%;
	max-height: 100%;
}

.scanner-preview-img,
.scanner-result-img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.scanner-edge-lines {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.scanner-corner-handle {
	position: absolute;
	width: 1rem;
	height: 1rem;
	border: 2px solid var(--sc-accent);
	border-radius: var(--sc-radius-full);
	background: rgba(255, 255, 255, 0.8);
	transform: translate(-50%, -50%);
	cursor: grab;
}

/* ── Scanner controls ──────────────────────────────────────────────────── */

.scanner-controls {
	padding: var(--sc-space-lg);
	display: flex;
	justify-content: center;
	border-top: var(--sc-border-width) solid var(--sc-border-subtle);
}

.scanner-capture-btn {
	width: 4.5rem;
	height: 4.5rem;
	border-radius: var(--sc-radius-full);
	border: 3px solid var(--sc-accent);
	background: transparent;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: transform var(--sc-transition-fast) var(--sc-ease-default);
}

.scanner-capture-btn:hover {
	transform: scale(1.05);
}

.scanner-capture-btn:active {
	transform: scale(0.95);
}

.scanner-capture-inner {
	width: 3.5rem;
	height: 3.5rem;
	border-radius: var(--sc-radius-full);
	background: var(--sc-accent);
}

.scanner-adjust-controls {
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: var(--sc-space-md);
}

.scanner-slider-row {
	display: flex;
	align-items: center;
	gap: var(--sc-space-md);
}

.scanner-slider-label {
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	white-space: nowrap;
}

.scanner-slider {
	flex: 1;
	accent-color: var(--sc-accent);
}

.scanner-checkbox-label {
	display: flex;
	align-items: center;
	gap: var(--sc-space-sm);
	font-size: var(--sc-text-sm);
	color: var(--sc-text-primary);
	cursor: pointer;
}

.scanner-action-row {
	display: flex;
	gap: var(--sc-space-md);
	justify-content: center;
}

/* ── Responsive ────────────────────────────────────────────────────────── */

@media (max-width: 639px) {
	.memory-create {
		padding: var(--sc-space-md) var(--sc-space-sm);
		padding-bottom: 6rem;
	}

	.memory-create-tab {
		font-size: var(--sc-text-sm);
		padding: var(--sc-space-sm);
		gap: var(--sc-space-xs);
	}

	.flex-date-row {
		flex-wrap: wrap;
	}

	.flex-date-field--narrow {
		flex: 1 0 5rem;
	}

	.flex-date-precision {
		flex-wrap: wrap;
	}

	.flex-date-precision-btn {
		flex: 1 0 calc(50% - var(--sc-space-xs));
	}

	.scanner-container {
		max-width: 100%;
		border-radius: 0;
	}
}

@media (min-width: 640px) {
	.scanner-container {
		max-height: 90vh;
		border-radius: var(--sc-radius-lg);
		overflow: hidden;
	}
}

@media (min-width: 1024px) {
	.memory-create-save-bar {
		bottom: 0;
	}
}

/* ── Method selector cards (Record + Photos) ──────────────────────────── */

.method-cards {
	display: flex;
	justify-content: center;
	gap: var(--sc-space-lg);
	padding: var(--sc-space-xl) 0;
	flex-wrap: wrap;
}

.method-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--sc-space-xl) var(--sc-space-lg);
	background: var(--sc-surface);
	border: var(--sc-border-width) solid var(--sc-border-subtle);
	border-radius: var(--sc-radius-lg);
	box-shadow: var(--sc-shadow-sm);
	cursor: pointer;
	transition: border-color var(--sc-transition-normal) var(--sc-ease-default),
	            box-shadow var(--sc-transition-normal) var(--sc-ease-default),
	            transform var(--sc-transition-normal) var(--sc-ease-default);
	width: 10rem;
	max-width: 12rem;
	flex-shrink: 0;
}

.method-card:hover {
	border-color: var(--sc-accent);
	box-shadow: var(--sc-shadow-md);
	transform: translateY(-2px);
}

.method-card:active {
	transform: translateY(0);
}

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

.method-card-icon {
	width: 2.5rem;
	height: 2.5rem;
	color: var(--sc-accent);
	margin-bottom: var(--sc-space-md);
}

.method-card-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-bottom: var(--sc-space-xs);
}

.method-card-desc {
	font-size: var(--sc-text-sm);
	color: var(--sc-text-secondary);
	line-height: var(--sc-leading-normal);
}

.memory-create-prompt {
	text-align: center;
	font-family: var(--sc-font-display);
	font-size: var(--sc-text-lg);
	color: var(--sc-text-secondary);
	margin-bottom: var(--sc-space-sm);
}

@media (max-width: 639px) {
	.method-card {
		flex: 1;
		min-width: 0;
		width: auto;
		max-width: none;
		padding: var(--sc-space-lg) var(--sc-space-md);
	}

	.method-card-icon {
		width: 2rem;
		height: 2rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.method-card:hover {
		transform: none;
	}
}
