:root[data-theme="light"] {
	--bg-a: #f4f7f2;
	--bg-b: #dde6e0;
	--panel: #fffefa;
	--panel-surface: #fffefa;
	--panel-shadow: 0 12px 28px rgba(17, 26, 22, 0.08);
	--ink: #13211a;
	--ink-soft: #455a50;
	--accent: #0a7a5a;
	--accent-2: #315fc4;
	--line: #c6d2ca;
	--control-border: color-mix(in srgb, var(--accent) 50%, black);
	--control-bg-top: #edf8f2;
	--control-bg-bottom: #d9eee3;
	--control-ink: var(--ink);
	--input-bg: #ffffff;
	--input-ink: var(--ink);
	--surface-soft: #f3f7f4;
	--surface-strong: #ffffff;
	--preview-bg: #12161c;
	--theme-btn-bg-top: #fff4bf;
	--theme-btn-bg-bottom: #ffdf7e;
	--theme-btn-border: #c89b2b;
	--theme-btn-ink: #3b2b08;
	--danger: #b43a2e;
}

:root,
:root[data-theme="dark"] {
	--bg-a: #151719;
	--bg-b: #20231f;
	--panel: #20241f;
	--panel-surface: #222720;
	--panel-shadow: 0 14px 30px rgba(0, 0, 0, 0.32);
	--ink: #eef2e8;
	--ink-soft: #bdc9b8;
	--accent: #79bf88;
	--accent-2: #7fb4de;
	--line: #465141;
	--control-border: #63705d;
	--control-bg-top: #31392f;
	--control-bg-bottom: #2a3228;
	--control-ink: #f1f7ec;
	--input-bg: #171b16;
	--input-ink: #f1f7ec;
	--surface-soft: #252c23;
	--surface-strong: #1b201a;
	--preview-bg: #101418;
	--theme-btn-bg-top: #ffeaa3;
	--theme-btn-bg-bottom: #e0c166;
	--theme-btn-border: #b88f2f;
	--theme-btn-ink: #2f2204;
	--danger: #ff8e7e;
}

:root[data-theme="grey"] {
	--bg-a: #4f5652;
	--bg-b: #3f4744;
	--panel: #59625d;
	--panel-surface: #5f6863;
	--panel-shadow: 0 12px 24px rgba(20, 24, 22, 0.34);
	--ink: #f2f6f0;
	--ink-soft: #d1dbd1;
	--accent: #a9d08e;
	--accent-2: #a6c3ef;
	--line: #879287;
	--control-border: #a0aaa0;
	--control-bg-top: #737d74;
	--control-bg-bottom: #657066;
	--control-ink: #f6faf4;
	--input-bg: #535d55;
	--input-ink: #f6faf4;
	--surface-soft: #56615a;
	--surface-strong: #667067;
	--preview-bg: #11161b;
	--theme-btn-bg-top: #eceff4;
	--theme-btn-bg-bottom: #cfd5df;
	--theme-btn-border: #9aa5b5;
	--theme-btn-ink: #2a3440;
	--danger: #ffc0b7;
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	min-height: 100vh;
	font-family: "Space Grotesk", system-ui, sans-serif;
	color: var(--ink);
	background:
		linear-gradient(160deg, color-mix(in srgb, var(--bg-a) 86%, #0f7354 14%), var(--bg-b));
}

.app {
	width: min(1480px, 96vw);
	margin: 24px auto 40px;
	display: grid;
	gap: 14px;
}

.app-header h1 {
	margin: 0;
	font-size: clamp(1.5rem, 3vw, 2.2rem);
	letter-spacing: 0;
}

.app-header p {
	margin: 4px 0 0;
	color: var(--ink-soft);
}

.panel {
	background: var(--panel-surface);
	border: 1px solid var(--line);
	border-radius: 8px;
	padding: 14px;
	box-shadow: var(--panel-shadow);
}

.panel-title-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	margin-bottom: 10px;
}

.panel h2 {
	margin: 0;
	font-size: 1.05rem;
	letter-spacing: 0;
}

.theme-toggle-btn {
	position: fixed;
	top: 12px;
	right: 12px;
	z-index: 140;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	border: 1px solid var(--theme-btn-border);
	background: linear-gradient(180deg, var(--theme-btn-bg-top), var(--theme-btn-bg-bottom));
	color: var(--theme-btn-ink);
	box-shadow: 0 7px 20px rgba(12, 18, 15, 0.22);
	line-height: 1;
	padding: 0;
}

.auth-user-bar {
	position: fixed;
	top: 12px;
	right: 68px;
	z-index: 140;
	display: flex;
	align-items: center;
	gap: 8px;
	max-width: min(560px, calc(100vw - 130px));
	min-height: 44px;
	padding: 6px 8px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
	box-shadow: var(--panel-shadow);
}

.auth-user-bar span {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: var(--ink-soft);
	font-size: 0.84rem;
}

.auth-user-bar a {
	color: var(--accent-2);
	font-weight: 700;
	text-decoration: none;
}

.auth-user-bar button {
	min-height: 32px;
	padding: 6px 9px;
}

button,
input,
select {
	font: inherit;
}

button {
	border: 1px solid var(--control-border);
	background: linear-gradient(180deg, var(--control-bg-top), var(--control-bg-bottom));
	color: var(--control-ink);
	border-radius: 8px;
	padding: 8px 12px;
	cursor: pointer;
	line-height: 1.15;
}

a.button-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--control-border);
	border-radius: 8px;
	padding: 8px 12px;
	background: linear-gradient(180deg, var(--control-bg-top), var(--control-bg-bottom));
	color: var(--control-ink);
	font: inherit;
	line-height: 1.15;
	text-decoration: none;
	cursor: pointer;
}

button:hover {
	border-color: color-mix(in srgb, var(--accent) 65%, var(--control-border));
}

a.button-link:hover {
	border-color: color-mix(in srgb, var(--accent) 65%, var(--control-border));
}

button:disabled {
	cursor: not-allowed;
	opacity: 0.56;
}

button.primary-action {
	min-height: 44px;
	padding: 11px 18px;
	border-color: color-mix(in srgb, var(--accent) 76%, black);
	background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, white), color-mix(in srgb, var(--accent) 76%, black));
	color: color-mix(in srgb, var(--ink) 12%, white);
	font-weight: 700;
	box-shadow: 0 10px 22px color-mix(in srgb, var(--accent) 22%, transparent);
}

button.primary-action:hover {
	border-color: color-mix(in srgb, var(--accent) 92%, white);
	box-shadow: 0 12px 28px color-mix(in srgb, var(--accent) 30%, transparent);
}

button:focus-visible,
a.tab-btn:focus-visible,
a.button-link:focus-visible,
input:focus-visible,
select:focus-visible,
.drop-zone:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--accent) 70%, white);
	outline-offset: 2px;
}

input,
select {
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	border: 1px solid var(--line);
	background: var(--input-bg);
	color: var(--input-ink);
	border-radius: 6px;
	padding: 7px 8px;
	min-height: 36px;
}

label,
.field-control {
	display: grid;
	gap: 4px;
	color: var(--ink-soft);
	font-size: 0.86rem;
}

label input,
label select,
.field-control input,
.field-control select {
	color: var(--input-ink);
	font-size: 0.92rem;
}

.hidden {
	display: none !important;
}

.tab-bar {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	border: 1px solid var(--line);
	border-radius: 8px;
	padding: 5px;
	background: var(--surface-strong);
	width: fit-content;
	max-width: 100%;
}

.tab-btn {
	min-width: 110px;
	border-color: transparent;
	background: transparent;
	box-shadow: none;
}

a.tab-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid transparent;
	border-radius: 8px;
	padding: 8px 12px;
	background: transparent;
	color: var(--control-ink);
	font: inherit;
	line-height: 1.15;
	text-decoration: none;
	cursor: pointer;
	box-shadow: none;
}

button.tab-btn:hover,
a.tab-btn:hover {
	border-color: color-mix(in srgb, var(--accent) 65%, var(--control-border));
}

.tab-btn.is-active {
	border-color: color-mix(in srgb, var(--accent) 70%, var(--control-border));
	background: linear-gradient(180deg, var(--control-bg-top), var(--control-bg-bottom));
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 45%, transparent);
}

.segmented-btn.is-active {
	border-color: color-mix(in srgb, var(--accent) 80%, black);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 55%, transparent);
}

.tab-panel {
	display: grid;
	gap: 14px;
}

.tab-panel.hidden {
	display: none !important;
}

.workspace-grid {
	display: grid;
	grid-template-columns: minmax(280px, 390px) minmax(0, 1fr);
	gap: 14px;
	align-items: start;
}

.debug-results-panel,
.worst-results-panel {
	min-width: 0;
}

.worst-results-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 12px;
}

.worst-result-card {
	display: grid;
	gap: 10px;
	padding: 10px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-soft);
	min-width: 0;
}

.worst-result-title {
	display: grid;
	gap: 2px;
}

.worst-result-title strong {
	font-size: 0.92rem;
	line-height: 1.25;
	overflow-wrap: anywhere;
}

.worst-result-title span {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.78rem;
}

.worst-result-images {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
}

.worst-result-image {
	display: grid;
	gap: 5px;
	min-width: 0;
}

.worst-result-image span {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.72rem;
}

.worst-result-image img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 14 / 9;
	object-fit: contain;
	border: 1px solid var(--line);
	border-radius: 6px;
	background:
		linear-gradient(45deg, rgba(255, 255, 255, 0.07) 25%, transparent 25%),
		linear-gradient(-45deg, rgba(255, 255, 255, 0.07) 25%, transparent 25%),
		linear-gradient(45deg, transparent 75%, rgba(255, 255, 255, 0.07) 75%),
		linear-gradient(-45deg, transparent 75%, rgba(255, 255, 255, 0.07) 75%),
		var(--preview-bg);
	background-size: 18px 18px;
	background-position: 0 0, 0 9px, 9px -9px, -9px 0;
}

.control-column {
	display: grid;
	gap: 14px;
}

.inline-controls,
.button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.settings-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
	gap: 10px;
	align-items: end;
}

.color-grid {
	grid-template-columns: 1fr;
}

.color-control {
	display: block;
}

.color-control .registration-color-input,
.color-control .color-picker {
	width: 100%;
	min-width: 0;
}

.color-control .color-picker .cp_input {
	display: none !important;
}

.color-control .color-picker .cp_button {
	width: 100%;
	aspect-ratio: auto;
	min-height: 36px;
	border-radius: 6px;
}

.color-control .color-picker .cp_caret {
	display: none;
}

.checkbox-label {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--ink);
	min-height: 36px;
}

.checkbox-label input {
	min-height: auto;
}

.compact-checkbox-label {
	min-height: 30px;
}

.patch-chart-toggle {
	margin-left: auto;
	white-space: nowrap;
	font-size: 0.86rem;
}

.segmented-control {
	display: inline-grid;
	grid-template-columns: repeat(2, minmax(98px, 1fr));
	gap: 6px;
}

.detection-mode-field,
.detection-mode-control {
	grid-column: 1 / -1;
}

.segmented-btn {
	background: var(--surface-soft);
	border-color: var(--line);
}

.drop-zone {
	display: grid;
	gap: 8px;
	align-items: center;
	justify-items: center;
	min-height: 132px;
	padding: 18px;
	border: 1px dashed color-mix(in srgb, var(--line) 70%, var(--accent));
	border-radius: 8px;
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--surface-soft) 90%, var(--accent) 10%), var(--surface-soft));
	color: var(--ink);
	text-align: center;
	cursor: pointer;
}

.drop-zone span {
	font-weight: 700;
}

.drop-zone strong {
	max-width: 100%;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.78rem;
	font-weight: 500;
	color: var(--ink-soft);
	word-break: break-word;
}

.drop-zone.is-dragging {
	border-color: var(--accent);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 60%, transparent);
}

.hidden-file-input {
	position: absolute;
	width: 1px;
	height: 1px;
	opacity: 0;
	pointer-events: none;
}

.crop-editor {
	overflow: hidden;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--preview-bg);
}

#cropCanvas {
	display: block;
	width: 100%;
	height: auto;
	cursor: grab;
}

#cropCanvas.is-dragging {
	cursor: grabbing;
}

.range-label {
	grid-template-columns: 1fr auto;
	align-items: center;
	column-gap: 10px;
}

.range-label input {
	grid-column: 1 / -1;
	width: 100%;
	padding: 0;
	min-height: 28px;
	accent-color: var(--accent);
}

.range-value {
	color: var(--ink);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.82rem;
}

.preview-panel {
	min-width: 0;
}

.preview-frame {
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background:
		linear-gradient(45deg, rgba(255, 255, 255, 0.06) 25%, transparent 25%),
		linear-gradient(-45deg, rgba(255, 255, 255, 0.06) 25%, transparent 25%),
		linear-gradient(45deg, transparent 75%, rgba(255, 255, 255, 0.06) 75%),
		linear-gradient(-45deg, transparent 75%, rgba(255, 255, 255, 0.06) 75%),
		var(--preview-bg);
	background-size: 24px 24px;
	background-position: 0 0, 0 12px, 12px -12px, -12px 0;
	border: 1px solid var(--line);
	border-radius: 8px;
	max-height: min(72vh, 860px);
	min-height: 220px;
}

.preview-frame canvas {
	display: block;
	width: auto;
	max-width: 100%;
	max-height: min(72vh, 860px);
	height: auto;
	background: transparent;
}

.webgl-frame canvas {
	touch-action: none;
	cursor: grab;
}

.webgl-frame canvas.is-dragging {
	cursor: grabbing;
}

.preview-meta {
	margin-top: 8px;
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.82rem;
	word-break: break-word;
}

.preview-meta.is-error {
	color: var(--danger);
}

.inline-meta {
	margin-top: 0;
	text-align: right;
}

.button-row.stacked-button-row {
	align-items: stretch;
	flex-direction: column;
}

.simulate-mode-list {
	display: grid;
	gap: 8px;
}

.simulate-mode-item {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 8px;
	align-items: start;
	padding: 9px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-soft);
}

.simulate-mode-item input {
	margin-top: 3px;
}

.simulate-mode-item strong {
	display: block;
	color: var(--ink);
	font-size: 0.9rem;
	font-weight: 700;
}

.simulate-mode-item span {
	display: block;
	margin-top: 2px;
	color: var(--ink-soft);
	font-size: 0.78rem;
	line-height: 1.25;
}

.simulate-results {
	display: grid;
	gap: 14px;
	min-width: 0;
}

.simulate-file-card,
.simulate-surface-card {
	min-width: 0;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-strong);
	overflow: hidden;
}

.simulate-file-head,
.simulate-surface-head {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	align-items: baseline;
	padding: 10px 12px;
	background: var(--surface-soft);
	border-bottom: 1px solid var(--line);
}

.simulate-file-head strong,
.simulate-surface-head strong {
	color: var(--ink);
	overflow-wrap: anywhere;
}

.simulate-file-head span,
.simulate-surface-head span {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.76rem;
	white-space: nowrap;
}

.simulate-surface-list {
	display: grid;
	gap: 10px;
	padding: 10px;
	min-width: 0;
}

.simulate-render-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 180px), 1fr));
	gap: 10px;
	padding: 10px;
	min-width: 0;
}

.simulate-render-tile {
	min-width: 0;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
	overflow: hidden;
}

.simulate-render-tile img {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	background: var(--preview-bg);
}

.simulate-render-label {
	display: grid;
	gap: 2px;
	padding: 8px;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.74rem;
	color: var(--ink-soft);
}

.simulate-render-label strong {
	color: var(--ink);
	font-size: 0.78rem;
	overflow-wrap: anywhere;
}

.simulate-render-pending {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 180px;
	padding: 16px;
	color: var(--ink-soft);
	background: var(--preview-bg);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.8rem;
	text-align: center;
}

.calibration-material-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
	gap: 10px;
}

.calibrate-inputs-panel {
	display: grid;
	gap: 12px;
}

.calibrate-inputs-panel.is-collapsed .calibrate-inputs-body {
	display: none;
}

.calibrate-inputs-panel.is-collapsed .calibrate-gcode-toggle {
	display: none;
}

.calibrate-inputs-body {
	display: grid;
	gap: 14px;
}

.calibrate-input-header-actions {
	justify-content: flex-end;
}

.calibrate-input-section {
	display: grid;
	gap: 10px;
	padding: 12px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-strong);
}

.filament-input-section {
	background: color-mix(in srgb, var(--surface-strong) 78%, var(--surface-soft));
}

.calibrate-setup-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
	gap: 14px;
	align-items: start;
}

.calibration-options-grid {
	display: grid;
	gap: 12px;
}

.calibrate-pair-header-actions {
	justify-content: flex-end;
	gap: 8px;
}

.calibrate-action-row {
	justify-content: flex-end;
}

.calibrate-run-panel {
	display: grid;
	justify-items: center;
	gap: 8px;
	padding: 2px 0 4px;
}

button.calibrate-run-button {
	min-width: min(100%, 340px);
	min-height: 52px;
	border-color: #070808;
	background: linear-gradient(180deg, #33383a, #0b0d0e);
	color: #f5f7f2;
	font-size: 1rem;
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.34);
}

button.calibrate-run-button:hover {
	border-color: #5c6468;
	background: linear-gradient(180deg, #3d4245, #111315);
	box-shadow: 0 16px 34px rgba(0, 0, 0, 0.42);
}

.calibration-output-title-row {
	align-items: flex-start;
}

.calibration-output-title {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.calibration-output-title .inline-meta {
	text-align: left;
}

.calibration-output-controls {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 10px 12px;
	align-items: center;
}

.calibration-output-footer-actions {
	justify-content: flex-end;
	margin-top: 10px;
}

.calibration-sheets-panel {
	display: grid;
	gap: 14px;
}

.calibration-sheets-list {
	display: grid;
	gap: 14px;
}

.generated-sheets-top-actions {
	justify-content: flex-end;
}

.calibration-archive-actions {
	justify-content: flex-end;
}

.calibration-sheet-card {
	display: grid;
	gap: 12px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-strong);
	overflow: hidden;
}

.calibration-sheet-card-head {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	align-items: flex-start;
	padding: 12px;
	background: var(--surface-soft);
	border-bottom: 1px solid var(--line);
}

.calibration-sheet-title {
	display: grid;
	gap: 4px;
	min-width: 0;
}

.calibration-sheet-title strong {
	overflow-wrap: anywhere;
}

.calibration-sheet-title span,
.calibration-sheet-preview-meta span,
.calibration-sheet-filament-row span {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.74rem;
}

.calibration-sheet-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
}

.calibration-sheet-preview-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 10px;
	padding: 0 12px;
}

.calibration-sheet-preview-card {
	display: grid;
	gap: 8px;
	min-width: 0;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
	overflow: hidden;
}

.calibration-sheet-preview-card canvas,
.calibration-sheet-preview-card img,
.calibration-sheet-empty-preview {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 10;
	background: var(--preview-bg);
}

.calibration-sheet-preview-card img {
	object-fit: contain;
}

.generated-sheet-atlas-preview-link {
	display: block;
	min-width: 0;
	background: var(--preview-bg);
}

.generated-sheet-atlas-preview-link img {
	display: block;
}

.generated-sheet-atlas-preview-card .calibration-sheet-preview-meta strong {
	overflow-wrap: anywhere;
}

.calibration-sheet-empty-preview {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 18px;
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.78rem;
	text-align: center;
}

.calibration-sheet-preview-meta {
	display: grid;
	gap: 3px;
	padding: 8px 9px 10px;
}

.calibration-sheet-filaments {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
	gap: 8px;
	padding: 0 12px 12px;
}

.generated-sheet-atlas-list {
	display: grid;
	gap: 8px;
	padding: 0 12px 12px;
}

.generated-sheet-atlas-link {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 3px 10px;
	align-items: center;
	padding: 9px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
	color: var(--ink);
	text-decoration: none;
}

.generated-sheet-atlas-link:hover {
	border-color: color-mix(in srgb, var(--accent) 55%, var(--line));
}

.generated-sheet-atlas-link strong {
	align-self: end;
	overflow-wrap: anywhere;
}

.generated-sheet-download-icon {
	grid-column: 2;
	grid-row: 1 / 3;
	align-self: center;
	justify-self: end;
	display: block;
	width: 18px;
	height: 18px;
	color: var(--ink-soft);
	fill: none;
	stroke: currentColor;
	stroke-width: 1.8;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.generated-sheet-atlas-link:hover .generated-sheet-download-icon {
	color: var(--accent);
}

.generated-sheet-atlas-meta {
	grid-column: 1;
	align-self: start;
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.74rem;
}

.calibration-sheet-filament-row {
	display: grid;
	gap: 6px;
	padding: 9px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
}

.calibration-sheet-filament-swatches {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 6px;
}

.calibration-sheet-color-swatch {
	min-height: 38px;
	display: flex;
	align-items: flex-end;
	padding: 5px;
	border: 1px solid var(--line);
	border-radius: 6px;
	background: var(--sheet-swatch-color);
	color: #fff;
	font-size: 0.66rem;
	line-height: 1;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.82);
}

.calibration-sheet-color-swatch.is-empty {
	color: var(--ink-soft);
	background: repeating-linear-gradient(45deg, var(--surface-soft), var(--surface-soft) 6px, var(--panel-surface) 6px, var(--panel-surface) 12px);
	text-shadow: none;
}

.calibration-sheet-comparison-modal {
	width: min(1180px, calc(100vw - 32px));
	max-height: calc(100vh - 32px);
	display: grid;
	grid-template-rows: auto minmax(0, 1fr);
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
	overflow: hidden;
}

.calibration-sheet-comparison-body {
	min-height: 0;
	overflow: auto;
	padding: 12px;
}

.calibration-patch-comparison-view {
	display: grid;
	gap: 12px;
}

.calibration-patch-comparison-section {
	margin: 0;
}

.calibration-comparison-canvas-stack {
	position: relative;
	width: 100%;
	background: var(--preview-bg);
	overflow: hidden;
}

.calibration-comparison-canvas-stack canvas {
	display: block;
	width: 100%;
	height: auto;
	background: var(--preview-bg);
	transition: opacity 120ms ease;
}

.calibration-comparison-canvas-stack .calibration-hover-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.calibration-cleaned-assets-meta {
	padding: 10px;
}

.calibration-pair-list {
	display: grid;
	gap: 10px;
}

.calibration-upload-pair {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-strong);
	overflow: hidden;
}

.calibration-upload-pair-head {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	align-items: center;
	padding: 9px 10px;
	background: var(--surface-soft);
	border-bottom: 1px solid var(--line);
}

.calibration-upload-pair-head strong {
	color: var(--ink);
	overflow-wrap: anywhere;
}

.calibration-upload-pair-title {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 10px;
	min-width: 0;
}

.calibration-pair-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	align-items: center;
}

.calibration-pair-swatch {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 1px solid var(--line);
	border-radius: 5px;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16);
}

.calibration-upload-pair-body {
	display: grid;
	gap: 10px;
	padding: 10px;
}

.calibration-pair-drop-grid {
	display: grid;
	grid-template-columns: repeat(var(--calibration-drop-columns, 3), minmax(0, 1fr));
	gap: 8px;
}

.calibration-pair-drop {
	min-height: 104px;
	padding: 12px;
}

.calibration-pair-drop.is-disabled {
	cursor: not-allowed;
	opacity: 0.58;
}

.calibration-loaded-file-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px;
	align-items: center;
	width: 100%;
}

.calibration-file-remove-btn {
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border-radius: 50%;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.8rem;
	line-height: 1;
}

.calibration-pair-photo-preview,
.calibration-pair-surface-preview {
	display: block;
	width: 100%;
	max-height: 180px;
	object-fit: contain;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--preview-bg);
}

.calibration-pair-drop em {
	display: block;
	max-width: 100%;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.7rem;
	font-style: normal;
	line-height: 1.25;
	overflow-wrap: anywhere;
}

.manual-registration-launch {
	width: 100%;
	justify-content: center;
	margin-top: 2px;
}

.calibration-photo-align-ok {
	color: var(--accent);
}

.calibration-photo-align-fallback {
	color: var(--ink-soft);
}

.manual-registration-panel {
	display: grid;
	gap: 8px;
	padding-top: 8px;
	border-top: 1px solid var(--line);
}

.manual-registration-modal-backdrop {
	position: fixed;
	inset: 0;
	z-index: 60;
	display: grid;
	place-items: center;
	padding: 18px;
	background: rgba(0, 0, 0, 0.62);
}

.manual-registration-modal {
	width: min(1360px, 100%);
	max-height: min(920px, calc(100vh - 36px));
	display: grid;
	grid-template-rows: auto minmax(0, 1fr);
	overflow: hidden;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel);
	box-shadow: 0 28px 70px rgba(0, 0, 0, 0.44);
}

.manual-registration-modal-head {
	display: flex;
	justify-content: space-between;
	gap: 14px;
	align-items: flex-start;
	padding: 14px 16px;
	border-bottom: 1px solid var(--line);
	background: var(--panel-surface);
}

.manual-registration-modal-head strong,
.manual-registration-modal-head span {
	display: block;
}

.manual-registration-modal-head span {
	margin-top: 3px;
	color: var(--ink-soft);
	font-size: 0.82rem;
}

.manual-registration-modal-close {
	width: 34px;
	height: 34px;
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border-radius: 50%;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
}

.manual-registration-modal-body {
	min-height: 0;
	display: grid;
	grid-template-columns: minmax(420px, 1fr) minmax(330px, 0.62fr);
	gap: 14px;
	padding: 14px;
	overflow: auto;
}

.manual-registration-modal-foot {
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	padding: 0 14px 14px;
}

.manual-registration-editor,
.manual-registration-comparison {
	min-width: 0;
	display: grid;
	align-content: start;
	gap: 10px;
}

.manual-registration-toolbar,
.manual-registration-controls {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}

.manual-registration-toolbar .preview-meta {
	margin: 0;
}

.manual-registration-controls label {
	min-width: 168px;
	flex: 1 1 180px;
}

.manual-registration-canvas-wrap {
	position: relative;
}

.manual-registration-canvas {
	display: block;
	width: 100%;
	height: auto;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--preview-bg);
	cursor: crosshair;
}

.manual-registration-canvas-wrap.is-processing .manual-registration-canvas {
	cursor: progress;
}

.manual-registration-processing {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	border-radius: 8px;
	background: rgba(0, 0, 0, 0.46);
	color: #ffffff;
	font-size: 1rem;
	font-weight: 700;
	pointer-events: none;
}

.manual-registration-point-list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.manual-registration-point {
	min-height: 30px;
	padding: 5px 8px;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.72rem;
	line-height: 1.2;
	white-space: normal;
	text-align: left;
}

.manual-registration-point.is-detected {
	border-color: rgba(0, 231, 255, 0.48);
}

.manual-registration-point.is-manual,
.manual-registration-point.is-manual_refined {
	border-color: rgba(87, 242, 135, 0.55);
}

.manual-registration-point.is-selected {
	outline: 2px solid rgba(255, 213, 74, 0.65);
	outline-offset: 1px;
}

.manual-registration-compare-figure,
.manual-registration-edge-figure {
	display: grid;
	gap: 6px;
	margin: 0;
}

.manual-registration-compare-figure figcaption,
.manual-registration-edge-figure figcaption {
	color: var(--ink-soft);
	font-size: 0.76rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.manual-registration-compare-figure img,
.manual-registration-edge-figure img {
	display: block;
	width: 100%;
	max-height: 260px;
	object-fit: contain;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--preview-bg);
}

.manual-registration-compare-figure.is-swapped img {
	outline: 2px solid var(--accent-2);
	outline-offset: 2px;
}

.manual-registration-edge-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	color: var(--ink-soft);
	font-size: 0.74rem;
}

.manual-registration-edge-legend span {
	width: 12px;
	height: 12px;
	display: inline-block;
	border-radius: 50%;
}

.manual-registration-edge-legend .is-atlas {
	background: #00e0ff;
}

.manual-registration-edge-legend .is-photo {
	background: #ffa840;
}

.calibration-surface-picker {
	display: grid;
	gap: 8px;
}

.calibration-surface-thumb-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(82px, 1fr));
	gap: 7px;
}

.calibration-surface-thumb {
	display: grid;
	gap: 5px;
	padding: 5px;
	border-color: var(--line);
	background: var(--surface-soft);
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.68rem;
	text-align: center;
}

.calibration-surface-thumb.is-selected {
	border-color: var(--accent);
	color: var(--ink);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 55%, transparent);
}

.calibration-surface-thumb img {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	border-radius: 5px;
	background: var(--preview-bg);
}

.filament-slot {
	display: grid;
	gap: 7px;
	padding: 9px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-soft);
	align-self: start;
	min-width: 0;
}

.filament-slot-label {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
	font-size: 0.9rem;
	color: var(--ink);
}

.channel-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 26px;
	border: 1px solid var(--line);
	border-radius: 6px;
	background: var(--surface-strong);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-weight: 500;
}

.filament-slot-row {
	display: flex;
	gap: 8px;
	align-items: center;
	min-width: 0;
}

.filament-slot-field-label {
	min-width: 42px;
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.82rem;
	text-transform: uppercase;
}

.filament-color-display {
	display: block;
	flex: 1 1 auto;
	min-width: 0;
	min-height: 42px;
	padding: 0;
	border: 1px solid var(--line);
	border-radius: 6px;
	background: var(--filament-color, #888888);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16);
}

.calibration-material-row label {
	display: block;
	flex: 1 1 auto;
	margin: 0;
	min-height: auto;
	min-width: 0;
}

.filament-slot-row .filament-name-input,
.filament-slot-row .filament-td-input {
	flex: 1 1 auto;
	width: 100%;
	min-width: 0;
}

.calibration-material-meta {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.75rem;
}

.calibration-pair-grid,
.calibration-render-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 10px;
	padding: 10px;
}

.calibration-comparison-row {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
	gap: 12px;
	padding: 10px 10px 0;
}

.calibration-image-tile {
	min-width: 0;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--panel-surface);
	overflow: hidden;
}

.calibration-image-tile img {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: contain;
	background: var(--preview-bg);
}

.calibration-image-stack {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	background: var(--preview-bg);
	overflow: hidden;
}

.calibration-image-tile.is-large .calibration-image-stack {
	aspect-ratio: 16 / 10;
	min-height: 340px;
}

.calibration-image-stack img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: opacity 120ms ease;
}

.calibration-hover-image {
	opacity: 0;
}

.has-hover-image:hover .calibration-primary-image {
	opacity: 0;
}

.has-hover-image:hover .calibration-hover-image {
	opacity: 1;
}

@media (max-width: 760px) {
	.manual-registration-modal-body {
		grid-template-columns: 1fr;
	}

	.manual-registration-modal-backdrop {
		padding: 8px;
	}

	.manual-registration-modal {
		max-height: calc(100vh - 16px);
	}

	.calibration-comparison-row {
		grid-template-columns: 1fr;
	}

	.calibration-image-tile.is-large .calibration-image-stack {
		min-height: 220px;
	}
}

.calibration-heatmap-section {
	border-top: 1px solid var(--line);
	background: color-mix(in srgb, var(--surface-soft) 55%, transparent);
}

.calibration-section-title {
	display: block;
	padding: 10px 10px 0;
	color: var(--ink);
	font-size: 0.82rem;
}

.calibration-heatmap-grid {
	padding-top: 8px;
}

.measured-filament-summary {
	display: grid;
	gap: 8px;
	padding: 10px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-soft);
}

.measured-filament-summary > strong {
	color: var(--ink);
	font-size: 0.9rem;
}

.measured-filament-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
	gap: 8px;
}

.measured-filament-row {
	display: grid;
	gap: 3px;
	padding: 8px;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-strong);
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.76rem;
}

.measured-filament-row strong {
	color: var(--ink);
	font-family: "Space Grotesk", system-ui, sans-serif;
	font-size: 0.86rem;
}

.measured-filament-colors {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: 6px;
}

.measured-filament-swatch {
	min-height: 48px;
	display: flex;
	align-items: flex-end;
	padding: 6px;
	border: 1px solid var(--line);
	border-radius: 6px;
	background: var(--measured-color, #888888);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16);
}

.measured-filament-swatch span {
	display: inline-block;
	padding: 2px 5px;
	border-radius: 4px;
	background: rgba(0, 0, 0, 0.62);
	color: #fff;
	font-size: 0.68rem;
	line-height: 1.2;
}

.measured-filament-swatch.is-entered {
	min-height: 36px;
	opacity: 0.88;
}

.calibration-alignment-controls {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	padding: 10px;
	border-top: 1px solid var(--line);
	background: var(--surface-soft);
}

.calibration-alignment-controls .range-label,
.calibration-alignment-controls .button-row {
	grid-column: 1 / -1;
}

.dual-preview {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	align-items: start;
}

.preview-stack {
	min-width: 0;
}

.result-table-wrap {
	overflow: auto;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--surface-strong);
}

.result-table {
	width: 100%;
	border-collapse: collapse;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.78rem;
	table-layout: fixed;
}

.result-table th,
.result-table td {
	padding: 8px;
	border-bottom: 1px solid var(--line);
	text-align: left;
	vertical-align: top;
	overflow-wrap: anywhere;
}

.result-table th {
	color: var(--ink);
	background: var(--surface-soft);
}

.result-table tr:last-child td {
	border-bottom: 0;
}

.result-table th:nth-child(1),
.result-table td:nth-child(1) {
	width: 58%;
}

.result-table th:nth-child(2),
.result-table td:nth-child(2),
.result-table th:nth-child(3),
.result-table td:nth-child(3),
.result-table th:nth-child(4),
.result-table td:nth-child(4) {
	width: 14%;
	white-space: nowrap;
}

.gamut-workspace-grid {
	grid-template-columns: minmax(300px, 380px) minmax(0, 1fr);
}

.gamut-drop-zone {
	min-height: 98px;
	margin-bottom: 10px;
}

.gamut-visual-panel {
	display: grid;
	gap: 12px;
}

.gamut-view-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	align-items: stretch;
}

.gamut-view-stack {
	display: grid;
	grid-template-rows: minmax(0, 1fr) auto;
	min-width: 0;
}

.gamut-canvas-frame,
.gamut-3d-frame {
	position: relative;
	overflow: hidden;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--preview-bg);
	min-height: 340px;
	aspect-ratio: 4 / 3;
}

.gamut-canvas-frame canvas,
.gamut-3d-frame canvas {
	display: block;
	width: 100%;
	height: 100%;
	touch-action: none;
}

.gamut-3d-frame {
	cursor: grab;
}

.gamut-3d-frame:active {
	cursor: grabbing;
}

.gamut-similarity-section {
	display: grid;
	gap: 8px;
}

.gamut-similarity-frame {
	min-height: 260px;
	aspect-ratio: 10 / 3;
}

.gamut-detail-panel {
	min-height: 220px;
}

.gamut-selection-detail {
	display: grid;
	gap: 8px;
	max-height: 460px;
	overflow: auto;
}

.gamut-selection-header {
	display: grid;
	grid-template-columns: 44px 1fr;
	gap: 10px;
	align-items: center;
	color: var(--ink);
}

.gamut-selection-swatch {
	width: 44px;
	height: 44px;
	border: 1px solid var(--line);
	border-radius: 6px;
	background: var(--selection-color, #888888);
}

.gamut-selection-title {
	display: grid;
	gap: 2px;
	min-width: 0;
}

.gamut-selection-title strong {
	color: var(--ink);
	font-family: "Space Grotesk", system-ui, sans-serif;
	font-size: 0.94rem;
	overflow-wrap: anywhere;
}

.gamut-stack-preview {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(8px, 1fr));
	gap: 1px;
	min-height: 22px;
	border: 1px solid var(--line);
	border-radius: 5px;
	overflow: hidden;
	background: var(--surface-strong);
}

.gamut-stack-layer {
	min-height: 22px;
	background: var(--layer-color, #777777);
}

.gamut-stack-preview.is-vertical {
	display: flex;
	flex-direction: column;
	width: 42px;
	height: 180px;
	min-height: 180px;
	gap: 0;
}

.gamut-stack-preview.is-vertical .gamut-stack-layer {
	flex: 1 1 0;
	min-height: 3px;
	border-top: 1px solid rgba(0, 0, 0, 0.22);
}

.gamut-stack-preview.is-vertical .gamut-stack-layer:first-child {
	border-top: 0;
}

.gamut-stack-list {
	display: grid;
	gap: 8px;
}

.gamut-stack-entry {
	display: grid;
	gap: 4px;
	padding: 7px;
	border: 1px solid var(--line);
	border-radius: 7px;
	background: var(--surface-soft);
}

.gamut-stack-entry strong {
	color: var(--ink);
	font-family: "Space Grotesk", system-ui, sans-serif;
	font-size: 0.84rem;
}

.gamut-hover-tooltip {
	position: fixed;
	z-index: 60;
	width: min(420px, calc(100vw - 24px));
	max-height: min(520px, calc(100vh - 24px));
	overflow: auto;
	padding: 10px;
	border: 1px solid color-mix(in srgb, var(--accent) 36%, var(--line));
	border-radius: 8px;
	background: color-mix(in srgb, var(--panel) 94%, black);
	box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
	color: var(--ink);
	pointer-events: none;
	font-size: 0.84rem;
}

:root[data-theme="light"] .gamut-hover-tooltip {
	background: color-mix(in srgb, var(--panel) 96%, white);
	box-shadow: 0 16px 34px rgba(17, 26, 22, 0.18);
}

.gamut-hover-tooltip-title {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 8px;
	margin-bottom: 8px;
	font-weight: 700;
}

.gamut-hover-tooltip-title span {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.76rem;
	font-weight: 500;
}

.gamut-hover-tooltip-list {
	display: grid;
	gap: 8px;
}

.gamut-hover-tooltip-sample {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 8px;
	align-items: start;
	min-width: 0;
}

.gamut-hover-tooltip-sample.has-photo {
	grid-template-columns: minmax(0, 1fr) minmax(120px, 150px);
}

.gamut-hover-tooltip-sample-main {
	display: grid;
	gap: 6px;
	min-width: 0;
}

.gamut-hover-tooltip-sample .gamut-stack-preview {
	justify-self: start;
}

.gamut-hover-tooltip-sample-title {
	display: grid;
	gap: 2px;
	min-width: 0;
}

.gamut-hover-tooltip-sample-title strong {
	color: var(--ink);
	font-family: "Space Grotesk", system-ui, sans-serif;
	font-size: 0.84rem;
	overflow-wrap: anywhere;
}

.gamut-hover-tooltip-sample-title span,
.gamut-hover-tooltip-raw-meta {
	color: var(--ink-soft);
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.72rem;
	line-height: 1.25;
	overflow-wrap: anywhere;
}

.gamut-hover-tooltip .raw-offset-tooltip-visual {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 58px;
	gap: 8px;
	align-items: stretch;
	min-width: 0;
}

.gamut-hover-tooltip .raw-offset-stack-preview {
	display: flex;
	flex-direction: column;
	justify-content: stretch;
	gap: 3px;
	min-width: 0;
	height: 118px;
	padding: 6px;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 6px;
	background: color-mix(in srgb, var(--preview-bg) 82%, black);
}

:root[data-theme="light"] .gamut-hover-tooltip .raw-offset-stack-preview {
	border-color: rgba(0, 0, 0, 0.18);
	background: color-mix(in srgb, var(--preview-bg) 72%, white);
}

.gamut-hover-tooltip .raw-offset-stack-row {
	flex: 1 1 0;
	min-height: 14px;
	display: flex;
	align-items: stretch;
	min-width: 0;
}

.gamut-hover-tooltip .raw-offset-stack-fill {
	width: var(--offset-width, 18%);
	min-width: 18%;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: 0 6px;
	border-radius: 4px;
	background: var(--filament-color, #fff);
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.52),
		0 0 0 1px rgba(0, 0, 0, 0.56);
	color: #101412;
	font-family: "IBM Plex Mono", ui-monospace, monospace;
	font-size: 0.68rem;
	font-weight: 700;
	line-height: 1;
	overflow: hidden;
}

.gamut-hover-tooltip .raw-offset-stack-fill.is-dark-fill {
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.72),
		0 0 0 1px rgba(255, 255, 255, 0.42),
		0 1px 4px rgba(255, 255, 255, 0.22);
	color: #f4f7f2;
}

.gamut-hover-tooltip .raw-offset-stack-fill span {
	text-shadow: 0 1px 2px rgba(255, 255, 255, 0.55);
	white-space: nowrap;
}

.gamut-hover-tooltip .raw-offset-stack-fill.is-dark-fill span {
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.9);
}

.gamut-hover-tooltip .raw-offset-predicted-color {
	min-height: 118px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 6px;
	box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.16);
	background: var(--preview-bg);
}

:root[data-theme="light"] .gamut-hover-tooltip .raw-offset-predicted-color {
	border-color: rgba(0, 0, 0, 0.22);
}

.gamut-photo-crop {
	display: grid;
	gap: 4px;
	width: min(150px, 100%);
}

.gamut-photo-crop canvas {
	display: block;
	width: 100%;
	height: auto;
	border: 1px solid var(--line);
	border-radius: 6px;
	background: var(--preview-bg);
}

.gamut-photo-crop span {
	color: var(--ink-soft);
	font-size: 0.76rem;
	overflow-wrap: anywhere;
}

@media (max-width: 980px) {
	.workspace-grid,
	.dual-preview,
	.calibration-pair-drop-grid,
	.calibrate-setup-grid,
	.gamut-workspace-grid,
	.gamut-view-grid {
		grid-template-columns: 1fr;
	}

	.calibration-output-controls,
	.calibrate-action-row {
		justify-content: flex-start;
	}
}

@media (max-width: 680px) {
	.panel-title-row {
		align-items: flex-start;
		flex-direction: column;
	}

	.theme-toggle-btn {
		position: absolute;
	}

	.tab-btn {
		flex: 1 1 0;
		min-width: 0;
	}

	.calibration-comparison-row {
		grid-template-columns: 1fr;
	}

	.calibration-image-tile.is-large .calibration-image-stack {
		min-height: 240px;
	}
}
