/* =========================================================================
   Pixel Forge Lite - Stylesheet
   Mobile-first with desktop overrides above 900px.
   ========================================================================= */

:root {
	--bg: #f7f8fb;
	--panel: #ffffff;
	--panel-soft: #f9fafb;
	--border: #d9e0ea;
	--border-strong: #bec8d6;
	--text: #1f2937;
	--muted: #6b7280;
	--primary: #2563eb;
	--primary-soft: #dbeafe;
	--primary-strong: #1d4ed8;
	--danger: #dc2626;
	--success: #16a34a;
	--shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
	--shadow-strong: 0 20px 50px rgba(15, 23, 42, 0.18);
	--radius: 16px;
	--radius-sm: 12px;
	--touch-min: 44px;
	--header-h: 56px;
	--quickbar-h: 116px;
	--safe-bottom: env(safe-area-inset-bottom, 0px);
	--safe-top: env(safe-area-inset-top, 0px);
	--anim: 0.18s ease;
}

* {
	box-sizing: border-box;
	-webkit-tap-highlight-color: transparent;
}

html,
body {
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
	background: var(--bg);
	color: var(--text);
	font-family: "Inter", "Hiragino Sans", "Yu Gothic UI", system-ui, sans-serif;
	overscroll-behavior: none;
	-webkit-text-size-adjust: 100%;
}

body {
	overflow: hidden;
}

button,
input,
select {
	font: inherit;
	color: inherit;
}

button {
	cursor: pointer;
}

input[type="range"] {
	-webkit-appearance: none;
	appearance: none;
	background: transparent;
}

input[type="range"]::-webkit-slider-runnable-track {
	height: 6px;
	background: var(--border);
	border-radius: 999px;
}

input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 22px;
	height: 22px;
	margin-top: -8px;
	background: #fff;
	border: 2px solid var(--primary);
	border-radius: 50%;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.18);
	cursor: pointer;
}

input[type="range"]::-moz-range-track {
	height: 6px;
	background: var(--border);
	border-radius: 999px;
	border: none;
}

input[type="range"]::-moz-range-thumb {
	width: 20px;
	height: 20px;
	background: #fff;
	border: 2px solid var(--primary);
	border-radius: 50%;
	cursor: pointer;
}

/* ===== APP SHELL ===== */

.app-shell {
	display: flex;
	flex-direction: column;
	height: 100vh;
	height: 100dvh;
	gap: 8px;
	padding: 8px;
	padding-bottom: calc(8px + var(--safe-bottom));
}

/* ===== TOPBAR (mobile baseline) ===== */

.topbar {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 18px;
	box-shadow: var(--shadow);
	min-height: var(--header-h);
	flex: 0 0 auto;
}

.brand {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
	flex: 1;
}

.brand-mark {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: linear-gradient(135deg, #eff6ff, #dbeafe);
	border: 1px solid #c7dbff;
	display: grid;
	place-items: center;
	font-weight: 800;
	font-size: 0.85rem;
	color: var(--primary);
	flex: 0 0 auto;
}

.brand-text {
	min-width: 0;
}

.brand h1 {
	margin: 0;
	font-size: 1rem;
	font-weight: 800;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.brand-tag {
	display: none;
	margin: 2px 0 0;
	font-size: 0.85rem;
	color: var(--muted);
}

.topbar-actions {
	display: flex;
	gap: 6px;
	align-items: center;
	flex: 0 0 auto;
}

.toolbar-group {
	display: flex;
	gap: 6px;
	padding: 4px;
	background: var(--panel-soft);
	border: 1px solid var(--border);
	border-radius: 12px;
}

.toolbar-group.compact {
	padding: 2px 4px;
}

/* ===== WORKSPACE ===== */

.workspace {
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-height: 0;
	flex: 1;
	position: relative;
}

.sidebar {
	display: flex;
	flex-direction: column;
	gap: 10px;
	min-height: 0;
}

/* On mobile, sidebars are drawers (off-canvas) */
.sidebar.left,
.sidebar.right {
	position: fixed;
	top: 0;
	bottom: 0;
	width: min(86vw, 360px);
	background: var(--panel);
	z-index: 30;
	padding: 10px;
	padding-top: calc(10px + var(--safe-top));
	padding-bottom: calc(10px + var(--safe-bottom));
	overflow-y: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	box-shadow: var(--shadow-strong);
	transition: transform var(--anim);
}

.sidebar.left {
	left: 0;
	transform: translateX(-101%);
	border-right: 1px solid var(--border);
	border-radius: 0 22px 22px 0;
}

.sidebar.right {
	right: 0;
	transform: translateX(101%);
	border-left: 1px solid var(--border);
	border-radius: 22px 0 0 22px;
}

.sidebar.open {
	transform: translateX(0);
}

.drawer-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--border);
}

.drawer-header h2 {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 800;
}

.drawer-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.36);
	z-index: 25;
	opacity: 0;
	transition: opacity var(--anim);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

.drawer-backdrop.show {
	opacity: 1;
}

.drawer-backdrop[hidden] {
	display: none;
}

/* ===== EDITOR CENTER ===== */

.editor-center {
	display: flex;
	flex-direction: column;
	gap: 8px;
	min-width: 0;
	min-height: 0;
	flex: 1;
}

.statusbar,
.bottombar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 14px;
	box-shadow: var(--shadow);
	font-size: 0.85rem;
	flex: 0 0 auto;
}

.statusbar {
	font-variant-numeric: tabular-nums;
	font-size: 0.8rem;
}

.bottombar {
	flex-wrap: wrap;
}

.canvas-stage {
	position: relative;
	flex: 1;
	min-height: 0;
	background: #f5f6f8;
	border: 1px solid var(--border);
	border-radius: 18px;
	box-shadow: var(--shadow);
	overflow: hidden;
	touch-action: none;
	user-select: none;
	-webkit-user-select: none;
}

.canvas-stage.checker-on {
	background-image:
		linear-gradient(45deg, #eef1f5 25%, transparent 25%),
		linear-gradient(-45deg, #eef1f5 25%, transparent 25%),
		linear-gradient(45deg, transparent 75%, #eef1f5 75%),
		linear-gradient(-45deg, transparent 75%, #eef1f5 75%);
	background-size: 24px 24px;
	background-position: 0 0, 0 12px, 12px -12px, -12px 0;
}

.canvas-stage canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	image-rendering: pixelated;
	image-rendering: crisp-edges;
}

.canvas-stage.cursor-pen {
	cursor: crosshair;
}

.canvas-stage.cursor-pan {
	cursor: grab;
}

.canvas-stage.cursor-pan.is-panning {
	cursor: grabbing;
}

.canvas-stage.cursor-pick {
	cursor: cell;
}

.zoom-group,
.inline-actions {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

.hint-row {
	color: var(--muted);
	font-size: 0.85rem;
}

/* ===== QUICKBAR (mobile bottom) ===== */

.quickbar {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 8px;
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: 16px;
	box-shadow: var(--shadow);
	flex: 0 0 auto;
}

.quickbar-row {
	display: flex;
	align-items: center;
	gap: 6px;
	min-height: 48px;
}

.quickbar-row.tool-row {
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 2px;
}

.quickbar-row.tool-row::-webkit-scrollbar {
	height: 0;
	display: none;
}

.color-preview-quick {
	width: 44px;
	height: 44px;
	min-width: 44px;
	border-radius: 12px;
	border: 1px solid var(--border-strong);
	background: #000;
	box-shadow: inset 0 0 0 2px #fff;
	flex: 0 0 auto;
}

.quick-palette {
	display: flex;
	gap: 4px;
	flex: 1;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	padding: 0 2px;
	min-height: 36px;
	align-items: center;
}

.quick-palette::-webkit-scrollbar {
	height: 0;
	display: none;
}

.quick-palette-swatch {
	width: 36px;
	height: 36px;
	min-width: 36px;
	border-radius: 10px;
	border: 1px solid var(--border);
	background: #fff;
	flex: 0 0 auto;
	scroll-snap-align: start;
}

.quick-palette-swatch.active {
	border-color: var(--primary);
	box-shadow: 0 0 0 2px var(--primary-soft);
}

.quick-tool-btn {
	width: 52px;
	height: 52px;
	min-width: 52px;
	border-radius: 12px;
	border: 1px solid var(--border);
	background: #fff;
	color: var(--text);
	display: grid;
	place-items: center;
	font-size: 1.4rem;
	scroll-snap-align: start;
	flex: 0 0 auto;
	transition: var(--anim);
}

.quick-tool-btn.active {
	background: var(--primary-soft);
	border-color: #9cc1ff;
	color: #0f3d9e;
}

/* ===== PANELS ===== */

.panel {
	background: var(--panel);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 12px;
}

.panel-header {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 12px;
	margin-bottom: 10px;
}

.panel-header.between {
	justify-content: space-between;
}

.panel-header h2,
.panel-subtitle {
	margin: 0;
	font-size: 0.95rem;
	font-weight: 800;
}

.panel-subtitle {
	margin-top: 12px;
	margin-bottom: 8px;
	display: flex;
	align-items: baseline;
	gap: 8px;
}

.panel-note {
	margin: 8px 0 0;
	font-size: 0.78rem;
	color: var(--muted);
}

.hint-inline {
	font-size: 0.72rem;
	font-weight: 500;
	color: var(--muted);
}

/* ===== TOOL GRID ===== */

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

.tool-btn {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 12px;
	min-height: var(--touch-min);
	border-radius: 14px;
	border: 1px solid var(--border);
	background: #fff;
	color: var(--text);
	transition: var(--anim);
	text-align: left;
}

.tool-btn:hover,
.btn:hover {
	border-color: var(--border-strong);
}

.tool-btn:active,
.btn:active {
	transform: translateY(1px);
}

.tool-btn.active {
	background: var(--primary-soft);
	border-color: #9cc1ff;
	color: #0f3d9e;
}

.tool-icon {
	width: 28px;
	height: 28px;
	border-radius: 10px;
	background: #f3f4f6;
	border: 1px solid var(--border);
	display: grid;
	place-items: center;
	font-size: 0.95rem;
	flex: 0 0 auto;
}

.tool-btn.active .tool-icon {
	background: #fff;
}

.tool-label {
	font-weight: 700;
	font-size: 0.88rem;
}

.tool-shortcut {
	font-size: 0.75rem;
	color: var(--muted);
	font-weight: 500;
}

/* ===== FIELDS ===== */

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

.field-row:last-child {
	margin-bottom: 0;
}

.field-row.stack {
	flex-direction: column;
	align-items: stretch;
	gap: 6px;
}

.field-row.stack > label {
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--muted);
}

.inline-field {
	display: flex;
	align-items: center;
	gap: 10px;
}

.inline-field.grow {
	flex: 1;
}

.toggle-row {
	justify-content: flex-start;
	min-height: var(--touch-min);
}

.toggle-row label {
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.9rem;
}

.toggle-row input[type="checkbox"] {
	width: 20px;
	height: 20px;
	accent-color: var(--primary);
	cursor: pointer;
}

.value-badge {
	min-width: 56px;
	padding: 6px 10px;
	text-align: center;
	border: 1px solid var(--border);
	border-radius: 12px;
	background: var(--panel-soft);
	font-variant-numeric: tabular-nums;
	font-size: 0.85rem;
}

.text-input,
input[type="color"] {
	width: 100%;
	min-height: 42px;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid var(--border);
	background: #fff;
	color: var(--text);
}

.text-input:focus,
input[type="color"]:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px var(--primary-soft);
}

input[type="color"] {
	padding: 4px;
	cursor: pointer;
}

input[type="range"] {
	width: 100%;
	min-height: 32px;
}

/* ===== SEGMENTED CONTROL ===== */

.seg-control {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 1fr;
	gap: 4px;
	padding: 4px;
	background: var(--panel-soft);
	border: 1px solid var(--border);
	border-radius: 12px;
}

.seg-btn {
	border: 1px solid transparent;
	background: transparent;
	color: var(--text);
	padding: 8px 6px;
	border-radius: 8px;
	font-size: 0.85rem;
	font-weight: 600;
	transition: var(--anim);
	min-height: 36px;
}

.seg-btn.active {
	background: #fff;
	border-color: var(--border);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
	color: var(--primary-strong);
}

/* ===== COLOR ===== */

.color-preview-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 12px;
}

.color-preview {
	width: 54px;
	height: 54px;
	border-radius: 14px;
	border: 1px solid var(--border-strong);
	background: #000;
	box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.6);
	flex: 0 0 auto;
}

.color-preview.secondary {
	position: relative;
	margin-left: -16px;
	margin-top: 18px;
	width: 46px;
	height: 46px;
	background: transparent;
}

.swatch-grid {
	display: grid;
	grid-template-columns: repeat(8, minmax(0, 1fr));
	gap: 6px;
}

.swatch {
	width: 100%;
	aspect-ratio: 1;
	border-radius: 10px;
	border: 1px solid var(--border);
	background: #fff;
	position: relative;
	transition: transform 0.1s ease;
	min-height: 32px;
}

.swatch.empty {
	background-image:
		linear-gradient(45deg, #eef1f5 25%, #fff 25%),
		linear-gradient(-45deg, #eef1f5 25%, #fff 25%),
		linear-gradient(45deg, #fff 75%, #eef1f5 75%),
		linear-gradient(-45deg, #fff 75%, #eef1f5 75%);
	background-size: 8px 8px;
	background-position: 0 0, 0 4px, 4px -4px, -4px 0;
	opacity: 0.5;
}

.swatch.active {
	border-color: var(--primary);
	box-shadow: 0 0 0 2px var(--primary-soft);
}

.swatch:active {
	transform: scale(0.94);
}

/* ===== ACTIONS GRID (edit panel) ===== */

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

/* ===== LAYERS ===== */

.layer-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	max-height: 320px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.layer-item {
	display: grid;
	grid-template-columns: 36px 1fr auto;
	gap: 10px;
	align-items: center;
	padding: 8px 10px;
	background: #fff;
	border: 1px solid var(--border);
	border-radius: 12px;
	min-height: var(--touch-min);
	text-align: left;
}

.layer-item.active {
	background: var(--primary-soft);
	border-color: #9cc1ff;
}

.layer-thumb {
	width: 36px;
	height: 36px;
	border-radius: 8px;
	border: 1px solid var(--border);
	background: #fff;
	image-rendering: pixelated;
	background-image:
		linear-gradient(45deg, #eef1f5 25%, transparent 25%),
		linear-gradient(-45deg, #eef1f5 25%, transparent 25%),
		linear-gradient(45deg, transparent 75%, #eef1f5 75%),
		linear-gradient(-45deg, transparent 75%, #eef1f5 75%);
	background-size: 8px 8px;
	background-position: 0 0, 0 4px, 4px -4px, -4px 0;
}

.layer-meta {
	min-width: 0;
}

.layer-name {
	font-weight: 700;
	font-size: 0.9rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.layer-sub {
	font-size: 0.78rem;
	color: var(--muted);
	margin-top: 2px;
}

.layer-flags {
	display: flex;
	gap: 4px;
}

.badge {
	padding: 4px 7px;
	border-radius: 999px;
	background: var(--panel-soft);
	border: 1px solid var(--border);
	font-size: 0.7rem;
}

.shortcut-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	font-size: 0.85rem;
}

kbd {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 3px 6px;
	border-radius: 6px;
	border: 1px solid var(--border);
	background: var(--panel-soft);
	font-family: inherit;
	font-size: 0.75rem;
	font-weight: 700;
	margin-right: 4px;
}

/* ===== BUTTONS ===== */

.btn {
	border: 1px solid var(--border);
	background: #fff;
	color: var(--text);
	padding: 9px 14px;
	border-radius: 12px;
	transition: var(--anim);
	min-height: var(--touch-min);
	font-size: 0.9rem;
	font-weight: 600;
}

.btn.small {
	padding: 7px 10px;
	font-size: 0.85rem;
	min-height: 38px;
	border-radius: 10px;
	font-weight: 600;
}

.btn.icon-btn {
	padding: 0 12px;
	min-width: 44px;
	font-size: 1.05rem;
	line-height: 2.3;
}

.btn.primary {
	background: var(--primary);
	border-color: var(--primary-strong);
	color: #fff;
}

.btn.primary:hover {
	background: var(--primary-strong);
}

.btn.danger {
	color: var(--danger);
}

.btn.danger:hover {
	background: #fef2f2;
}

.btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	transform: none;
}

.layer-order-actions {
	margin-bottom: 8px;
}

/* ===== VISIBILITY HELPERS ===== */

.desktop-only {
	display: none !important;
}

.mobile-only {
	display: initial;
}

button.mobile-only {
	display: inline-flex;
}

div.mobile-only,
section.mobile-only {
	display: block;
}

/* ===========================================================================
   TABLET / DESKTOP (>= 900px)
   =========================================================================== */

@media (min-width: 900px) {

	.app-shell {
		gap: 12px;
		padding: 12px;
	}

	.topbar {
		min-height: auto;
		padding: 12px 16px;
		border-radius: 22px;
		flex-wrap: wrap;
	}

	.brand {
		flex: 0 1 auto;
	}

	.brand-mark {
		width: 44px;
		height: 44px;
		border-radius: 14px;
		font-size: 1rem;
	}

	.brand h1 {
		font-size: 1.1rem;
	}

	.brand-tag {
		display: block;
	}

	.topbar-actions {
		gap: 10px;
		flex-wrap: wrap;
		justify-content: flex-end;
		margin-left: auto;
	}

	.toolbar-group {
		gap: 8px;
		padding: 6px;
		border-radius: 14px;
	}

	.toolbar-group.compact {
		padding: 4px 8px;
	}

	/* Workspace switches to 3 columns */
	.workspace {
		display: grid;
		grid-template-columns: 300px 1fr 320px;
		gap: 14px;
		flex: 1;
	}

	/* Sidebars become normal flex columns, not drawers */
	.sidebar.left,
	.sidebar.right {
		position: static;
		transform: none !important;
		width: auto;
		background: transparent;
		z-index: auto;
		padding: 0 2px 0 0;
		border: none !important;
		border-radius: 0 !important;
		box-shadow: none;
		overflow-y: auto;
		gap: 14px;
	}

	.sidebar.left {
		padding-right: 4px;
	}

	.sidebar.right {
		padding-left: 4px;
	}

	.drawer-header {
		display: none;
	}

	.drawer-backdrop {
		display: none !important;
	}

	.editor-center {
		gap: 12px;
	}

	.statusbar,
	.bottombar {
		padding: 10px 14px;
		border-radius: 16px;
		font-size: 0.92rem;
	}

	.canvas-stage {
		border-radius: 22px;
	}

	.panel {
		padding: 14px;
	}

	.panel-header {
		margin-bottom: 12px;
	}

	.tool-grid {
		gap: 10px;
	}

	.tool-btn {
		padding: 10px 12px;
	}

	.swatch-grid {
		grid-template-columns: repeat(8, minmax(0, 1fr));
		gap: 8px;
	}

	.actions-grid {
		gap: 10px;
	}

	.shortcut-list {
		gap: 10px;
	}

	.desktop-only {
		display: initial !important;
	}

	div.desktop-only,
	section.desktop-only {
		display: block !important;
	}

	button.desktop-only {
		display: inline-flex !important;
	}

	div.toolbar-group.desktop-only {
		display: flex !important;
	}

	.mobile-only {
		display: none !important;
	}
}

/* ===========================================================================
   WIDE DESKTOP (>= 1280px)
   =========================================================================== */

@media (min-width: 1280px) {
	.workspace {
		grid-template-columns: 320px 1fr 340px;
		gap: 16px;
	}

	.swatch-grid {
		grid-template-columns: repeat(8, minmax(0, 1fr));
	}

	.brand h1 {
		font-size: 1.15rem;
	}
}

/* ===========================================================================
   COMPACT DESKTOP (900-1100px) — single-column tablet-ish
   =========================================================================== */

@media (min-width: 900px) and (max-width: 1099px) {
	.workspace {
		grid-template-columns: 260px 1fr 280px;
	}
}

/* ===========================================================================
   NARROW MOBILE (<= 360px)
   =========================================================================== */

@media (max-width: 360px) {
	.brand h1 {
		font-size: 0.9rem;
	}

	.brand-mark {
		width: 32px;
		height: 32px;
		font-size: 0.8rem;
	}

	.btn.icon-btn {
		min-width: 40px;
		padding: 0 8px;
	}

	.swatch-grid {
		grid-template-columns: repeat(6, minmax(0, 1fr));
	}

	.tool-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ===========================================================================
   LANDSCAPE MOBILE (height < 500px)
   - Hide brand text to give canvas more height
   =========================================================================== */

@media (max-height: 500px) and (max-width: 899px) {
	.brand-text {
		display: none;
	}

	.statusbar {
		padding: 6px 10px;
		font-size: 0.75rem;
	}

	.quickbar {
		padding: 4px 6px;
		gap: 4px;
	}

	.quickbar-row {
		min-height: 40px;
	}

	.quick-tool-btn {
		width: 44px;
		height: 44px;
		min-width: 44px;
		font-size: 1.2rem;
	}

	.color-preview-quick {
		width: 40px;
		height: 40px;
		min-width: 40px;
	}

	.quick-palette-swatch {
		width: 32px;
		height: 32px;
		min-width: 32px;
	}
}

/* ===========================================================================
   PRINT / HIGH CONTRAST
   =========================================================================== */

@media (prefers-reduced-motion: reduce) {
	* {
		animation: none !important;
		transition: none !important;
	}
}
