/* SN Label Designer — front-end editor.
 * The designer is the hero of the product page: full-width across the top,
 * product gallery removed, summary (price + add-to-cart) sits beneath it. */

:root {
	--snld-accent: #e63946;
	--snld-accent-dark: #b81d28;
	--snld-accent-soft: #fde8ea;
	--snld-header-1: #1e3a8a;
	--snld-header-2: #3b82f6;
	--snld-ink: #1f2933;
	--snld-muted: #6b7785;
	--snld-line: #e3e8ee;
	--snld-surface: #ffffff;
	--snld-bg: #f6f8fb;
	--snld-radius: 16px;
	--snld-radius-sm: 10px;
	--snld-shadow: 0 10px 30px rgba( 31, 41, 51, 0.08 );
	--snld-shadow-sm: 0 2px 8px rgba( 31, 41, 51, 0.06 );
}

/* ---------- Layout takeover (designable products) ---------- */

.snld-designable .woocommerce-product-gallery,
.snld-designable .woocommerce-product-gallery--columns-4,
.snld-designable figure.woocommerce-product-gallery__wrapper {
	display: none !important;
}

.snld-designable .woocommerce div.product .summary,
.snld-designable .woocommerce div.product div.summary {
	float: none;
	width: 100%;
	margin: 0;
	max-width: 720px;
}

.snld-designable .woocommerce div.product {
	display: block;
}

/* ---------- App shell ---------- */

.snld-app {
	clear: both;
	float: none;
	width: 100%;
	margin: 0 0 36px;
	box-sizing: border-box;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	color: var( --snld-ink );
}

.snld-app *,
.snld-app *::before,
.snld-app *::after {
	box-sizing: border-box;
}

.snld-app__inner {
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius );
	box-shadow: var( --snld-shadow );
	overflow: hidden;
}

/* Plain heading that inherits the theme's product-title typography, so it sits
 * in keeping with standard product pages (no coloured banner). */
.snld-app__head {
	padding: 0;
	margin: 0 0 18px;
	background: none;
}

.snld-app__title {
	margin: 0 0 6px;
	/* Inherit the theme heading font/size/weight/colour. */
}

.snld-app__subtitle {
	margin: 0;
	font-size: 15px;
	color: var( --snld-muted );
}

.snld-app__body {
	display: grid;
	grid-template-columns: minmax( 0, 1.4fr ) minmax( 280px, 1fr );
	gap: 0;
}

/* ---------- Stage (live preview) ---------- */

.snld-stage {
	padding: 28px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	background:
		radial-gradient( circle at 1px 1px, rgba( 31, 41, 51, 0.06 ) 1px, transparent 0 ) 0 0 / 18px 18px,
		var( --snld-bg );
	border-right: 1px solid var( --snld-line );
}

.snld-stage__canvas-wrap {
	display: inline-block;
	padding: 14px;
	background: #fff;
	border-radius: var( --snld-radius-sm );
	box-shadow: var( --snld-shadow );
	/* Stay in view even when the controls column is tall. */
	position: sticky;
	top: 16px;
	z-index: 1;
}

.snld-stage canvas {
	display: block;
	border-radius: 4px;
}

.snld-hint {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12.5px;
	color: var( --snld-muted );
	margin: 16px 0 0;
}

/* ---------- Controls ---------- */

.snld-controls {
	padding: 24px;
	min-width: 0;
}

.snld-tabs {
	display: flex;
	gap: 6px;
	margin-bottom: 20px;
	padding: 4px;
	background: var( --snld-bg );
	border-radius: 12px;
}

.snld-tab {
	flex: 1 1 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	border: 0;
	background: transparent;
	padding: 9px 6px;
	border-radius: 9px;
	cursor: pointer;
	font-size: 13px;
	font-weight: 600;
	color: var( --snld-muted );
	transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.snld-tab__icon {
	font-size: 13px;
	line-height: 1;
}

.snld-tab:hover {
	color: var( --snld-ink );
}

.snld-tab.is-active {
	background: var( --snld-surface );
	color: var( --snld-accent-dark );
	box-shadow: var( --snld-shadow-sm );
}

/* Fields */

.snld-field {
	display: block;
	margin-bottom: 16px;
}

.snld-field__label {
	display: block;
	margin-bottom: 6px;
	font-size: 12.5px;
	font-weight: 600;
	color: var( --snld-muted );
}

.snld-field-row {
	display: flex;
	gap: 12px;
	align-items: flex-end;
}

.snld-field-row .snld-field {
	flex: 1 1 auto;
}

.snld-field--colour {
	flex: 0 0 auto;
}

.snld-app input[ type='text' ],
.snld-app select {
	width: 100%;
	padding: 10px 12px;
	font-size: 14px;
	color: var( --snld-ink );
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	outline: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.snld-app input[ type='text' ]:focus,
.snld-app select:focus {
	border-color: var( --snld-accent );
	box-shadow: 0 0 0 3px var( --snld-accent-soft );
}

.snld-app input[ type='color' ] {
	width: 46px;
	height: 42px;
	padding: 2px;
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	background: var( --snld-surface );
	cursor: pointer;
}

/* Buttons */

.snld-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 11px 16px;
	font-size: 14px;
	font-weight: 600;
	border-radius: var( --snld-radius-sm );
	border: 1px solid transparent;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
}

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

.snld-btn--primary {
	background: var( --snld-accent );
	color: #fff;
}

.snld-btn--primary:hover {
	background: var( --snld-accent-dark );
}

.snld-btn--ghost {
	background: var( --snld-surface );
	color: #b4232a;
	border-color: var( --snld-line );
}

.snld-btn--ghost:hover {
	background: #fff5f5;
	border-color: #f0c3c3;
}

.snld-btn--outline {
	background: var( --snld-surface );
	color: var( --snld-accent-dark );
	border-color: var( --snld-accent );
}

.snld-btn--outline:hover {
	background: var( --snld-accent-soft );
}

.snld-btn--dark {
	background: var( --snld-ink );
	color: #fff;
}

.snld-btn--dark:hover {
	background: #0f161d;
}

.snld-preview-btn {
	width: auto;
	margin-top: 16px;
	padding-left: 22px;
	padding-right: 22px;
}

/* ---------- Template carousel ---------- */

.snld-templates {
	padding: 18px 24px 20px;
	border-bottom: 1px solid var( --snld-line );
	background: var( --snld-surface );
}

.snld-templates__bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
	margin-bottom: 14px;
}

.snld-templates__lead {
	font-size: 13px;
	font-weight: 700;
	color: var( --snld-ink );
}

.snld-templates__filters {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.snld-chip {
	border: 1px solid var( --snld-line );
	background: var( --snld-bg );
	color: var( --snld-muted );
	border-radius: 999px;
	padding: 4px 12px;
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	text-transform: capitalize;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.snld-chip:hover {
	color: var( --snld-ink );
}

.snld-chip.is-active {
	background: var( --snld-accent );
	border-color: var( --snld-accent );
	color: #fff;
}

.snld-templates__carousel {
	display: flex;
	gap: 14px;
	overflow-x: auto;
	padding: 4px 2px 10px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
}

.snld-templates__carousel::-webkit-scrollbar {
	height: 8px;
}

.snld-templates__carousel::-webkit-scrollbar-thumb {
	background: var( --snld-line );
	border-radius: 999px;
}

.snld-templates__empty {
	font-size: 13px;
	color: var( --snld-muted );
	margin: 6px 0;
}

.snld-tpl-card {
	position: relative;
	flex: 0 0 auto;
	width: 132px;
	border: 1px solid var( --snld-line );
	background: var( --snld-surface );
	border-radius: var( --snld-radius-sm );
	padding: 8px;
	cursor: pointer;
	scroll-snap-align: start;
	text-align: center;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.08s ease;
}

.snld-tpl-card:hover {
	border-color: var( --snld-accent );
	box-shadow: var( --snld-shadow-sm );
	transform: translateY( -2px );
}

.snld-tpl-card__thumb {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 76px;
	border-radius: 8px;
	overflow: hidden;
	background: var( --snld-bg );
	margin-bottom: 8px;
}

.snld-tpl-card__thumb img {
	max-width: 100%;
	max-height: 100%;
	display: block;
}

.snld-tpl-card__name {
	display: block;
	font-size: 12.5px;
	font-weight: 600;
	color: var( --snld-ink );
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.snld-tpl-card__del {
	position: absolute;
	top: -8px;
	right: -8px;
	width: 22px;
	height: 22px;
	line-height: 20px;
	border-radius: 50%;
	background: #b4232a;
	color: #fff;
	font-size: 16px;
	text-align: center;
	box-shadow: var( --snld-shadow-sm );
}

.snld-tpl-card__del:hover {
	background: #8f1b21;
}

/* ---------- Admin: save master template ---------- */

.snld-admin {
	margin-top: 20px;
	padding: 16px;
	border: 1px dashed var( --snld-line );
	border-radius: var( --snld-radius-sm );
	background: var( --snld-bg );
}

.snld-admin__title {
	margin: 0 0 12px;
	font-size: 13px;
	font-weight: 700;
	color: var( --snld-ink );
}

.snld-admin__status {
	margin-top: 10px;
	font-size: 12.5px;
	font-weight: 600;
	color: var( --snld-accent-dark );
	min-height: 16px;
}

/* ---------- Preview modal ---------- */

.snld-modal[ hidden ] {
	display: none;
}

.snld-modal {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
}

.snld-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba( 15, 22, 29, 0.62 );
	backdrop-filter: blur( 2px );
}

.snld-modal__dialog {
	position: relative;
	max-width: 560px;
	width: 100%;
	background: var( --snld-surface );
	border-radius: var( --snld-radius );
	box-shadow: 0 24px 60px rgba( 0, 0, 0, 0.35 );
	padding: 28px;
	text-align: center;
	animation: snld-pop 0.16s ease-out;
}

@keyframes snld-pop {
	from { transform: scale( 0.96 ); opacity: 0; }
	to { transform: scale( 1 ); opacity: 1; }
}

.snld-modal__close {
	position: absolute;
	top: 10px;
	right: 10px;
	width: 34px !important;
	height: 34px !important;
	min-width: 0 !important;
	padding: 0 !important;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 0;
	border-radius: 50%;
	background: transparent;
	font-size: 24px !important;
	line-height: 1;
	color: var( --snld-muted );
	cursor: pointer;
}

.snld-modal__close:hover {
	color: var( --snld-ink );
}

.snld-modal__title {
	margin: 0 0 4px;
	font-size: 19px;
	font-weight: 700;
	color: var( --snld-ink );
}

.snld-modal__hint {
	margin: 0 0 20px;
	font-size: 13px;
	color: var( --snld-muted );
}

.snld-modal__stage {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 26px;
	border-radius: var( --snld-radius-sm );
	background:
		radial-gradient( circle at 1px 1px, rgba( 31, 41, 51, 0.06 ) 1px, transparent 0 ) 0 0 / 18px 18px,
		var( --snld-bg );
}

.snld-modal__stage img {
	max-width: 100%;
	max-height: 56vh;
	display: block;
	box-shadow: 0 6px 22px rgba( 0, 0, 0, 0.18 );
}

/* Icon + template grids */

.snld-icon-grid,
.snld-template-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 64px, 1fr ) );
	gap: 10px;
}

/* Scroll a large asset library instead of letting it grow the whole column. */
.snld-icon-grid {
	max-height: 360px;
	overflow-y: auto;
	padding: 2px 4px 2px 2px;
}

.snld-icon-grid::-webkit-scrollbar {
	width: 8px;
}

.snld-icon-grid::-webkit-scrollbar-thumb {
	background: var( --snld-line );
	border-radius: 999px;
}

.snld-icon-btn,
.snld-template-btn {
	border: 1px solid var( --snld-line );
	background: var( --snld-surface );
	border-radius: var( --snld-radius-sm );
	padding: 12px;
	cursor: pointer;
	min-height: 64px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.08s ease;
}

.snld-template-btn {
	font-size: 13px;
	font-weight: 600;
	color: var( --snld-ink );
	text-align: center;
	min-height: 56px;
}

.snld-icon-btn img {
	width: 100%;
	height: auto;
	max-height: 40px;
	display: block;
}

.snld-icon-btn:hover,
.snld-template-btn:hover {
	border-color: var( --snld-accent );
	box-shadow: var( --snld-shadow-sm );
	transform: translateY( -1px );
}

/* Palette */

.snld-palette {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 18px;
}

.snld-swatch {
	width: 34px;
	height: 34px;
	border-radius: 50%;
	border: 2px solid #fff;
	box-shadow: 0 0 0 1px var( --snld-line );
	cursor: pointer;
	padding: 0;
	transition: transform 0.08s ease, box-shadow 0.15s ease;
}

.snld-swatch:hover {
	transform: scale( 1.1 );
	box-shadow: 0 0 0 2px var( --snld-accent );
}

.snld-actions {
	margin-top: 20px;
	padding-top: 18px;
	border-top: 1px solid var( --snld-line );
}

/* Save status (lives in the add-to-cart form) */

.snld-save-status {
	font-size: 13px;
	font-weight: 600;
	color: var( --snld-accent-dark );
	margin: 4px 0 12px;
	min-height: 18px;
}

/* ---------- Responsive ---------- */

@media ( max-width: 768px ) {
	.snld-app__body {
		grid-template-columns: 1fr;
	}

	/* Put the design controls above the stage (so they sit before the
	 * canvas + save section, which feels more natural on a phone). */
	.snld-controls {
		order: 1;
		border-bottom: 1px solid var( --snld-line );
	}

	.snld-stage {
		order: 2;
		border-right: 0;
		border-bottom: 0;
	}

	/* No sticky preview on mobile — it just scrolls with the page. */
	.snld-stage__canvas-wrap {
		position: static;
	}

	.snld-app__head {
		padding: 18px 20px;
	}

	.snld-stage,
	.snld-controls {
		padding: 20px;
	}
}

/* ---------- Title suffix ---------- */

.snld-app__title-suffix {
	font-weight: 400;
	opacity: 0.6;
}

/* ---------- WYSIWYG font picker ---------- */

.snld-fontpicker {
	position: relative;
}

.snld-fontpicker__toggle {
	width: 100%;
	text-align: left;
	padding: 10px 32px 10px 12px;
	font-size: 16px;
	line-height: 1.2;
	color: var( --snld-ink );
	background: var( --snld-surface )
		url( "data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7785' d='M1 1l5 5 5-5'/%3E%3C/svg%3E" )
		no-repeat right 12px center;
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	cursor: pointer;
}

.snld-fontpicker__toggle:hover {
	border-color: var( --snld-accent );
}

.snld-fontpicker__menu {
	position: absolute;
	z-index: 50;
	top: calc( 100% + 6px );
	left: 0;
	right: 0;
	max-height: 280px;
	overflow-y: auto;
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	box-shadow: var( --snld-shadow );
	padding: 6px;
}

.snld-fontpicker__opt {
	display: block;
	width: 100%;
	text-align: left;
	padding: 9px 12px;
	font-size: 18px;
	line-height: 1.25;
	color: var( --snld-ink );
	background: transparent;
	border: 0;
	border-radius: 8px;
	cursor: pointer;
}

.snld-fontpicker__opt:hover {
	background: var( --snld-bg );
}

.snld-fontpicker__opt.is-active {
	background: var( --snld-accent-soft );
	color: var( --snld-accent-dark );
}

/* ---------- Colour trigger ---------- */

.snld-colourtrigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 42px;
	padding: 4px;
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	background: var( --snld-surface );
	cursor: pointer;
}

.snld-colourtrigger:hover {
	border-color: var( --snld-accent );
}

.snld-colourtrigger__sw {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 6px;
	box-shadow: inset 0 0 0 1px rgba( 0, 0, 0, 0.12 );
}

/* ---------- CMYK popover ---------- */

.snld-cmyk[ hidden ] {
	display: none;
}

.snld-cmyk {
	z-index: 100001;
	width: 260px;
	padding: 16px;
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius );
	box-shadow: 0 16px 40px rgba( 0, 0, 0, 0.22 );
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.snld-cmyk__preview {
	height: 44px;
	border-radius: 8px;
	margin-bottom: 14px;
	box-shadow: inset 0 0 0 1px rgba( 0, 0, 0, 0.12 );
}

.snld-cmyk__row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 8px;
}

.snld-cmyk__ch {
	width: 30px;
	font-size: 12px;
	font-weight: 700;
	color: var( --snld-muted );
	flex: 0 0 auto;
}

.snld-cmyk__range {
	flex: 1 1 auto;
	min-width: 0;
	width: auto;
	margin: 0;
}

.snld-cmyk__num {
	width: 52px;
	flex: 0 0 auto;
	padding: 5px 6px;
	font-size: 13px;
	border: 1px solid var( --snld-line );
	border-radius: 6px;
}

.snld-cmyk__hexrow {
	margin-top: 12px;
}

.snld-cmyk__hex {
	flex: 1 1 auto;
	padding: 7px 8px;
	font-size: 13px;
	border: 1px solid var( --snld-line );
	border-radius: 6px;
	text-transform: uppercase;
}

.snld-cmyk__done {
	margin-top: 6px;
}

/* ---------- Background pattern picker ---------- */

.snld-pattern-grid {
	display: grid;
	grid-template-columns: repeat( auto-fill, minmax( 56px, 1fr ) );
	gap: 8px;
}

.snld-pattern-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 56px;
	padding: 6px;
	font-size: 12px;
	font-weight: 600;
	color: var( --snld-muted );
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	cursor: pointer;
	overflow: hidden;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.08s ease;
}

.snld-pattern-btn canvas {
	display: block;
	width: 44px;
	height: 44px;
	border-radius: 6px;
}

.snld-pattern-btn:hover {
	border-color: var( --snld-accent );
	transform: translateY( -1px );
}

.snld-pattern-btn.is-active {
	border-color: var( --snld-accent );
	box-shadow: 0 0 0 2px var( --snld-accent-soft );
	color: var( --snld-accent-dark );
}

#snld-pattern-opts {
	margin-top: 4px;
}

#snld-pattern-size {
	width: 100%;
}

/* ---------- Pattern colour combos ---------- */

.snld-combos {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.snld-combo {
	position: relative;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	border: 2px solid #fff;
	box-shadow: 0 0 0 1px var( --snld-line );
	overflow: hidden;
	padding: 0;
	cursor: pointer;
	transition: transform 0.08s ease, box-shadow 0.15s ease;
}

.snld-combo:hover {
	transform: scale( 1.1 );
	box-shadow: 0 0 0 2px var( --snld-accent );
}

.snld-combo__bg,
.snld-combo__fg {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 50%;
}

.snld-combo__bg {
	left: 0;
}

.snld-combo__fg {
	right: 0;
}

/* ---------- Colour wheel + swatches in the CMYK popover ---------- */

.snld-cmyk__wheelwrap {
	position: relative;
	width: 150px;
	height: 150px;
	margin: 0 auto 12px;
}

.snld-cmyk__wheel {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	cursor: crosshair;
	box-shadow: inset 0 0 0 1px rgba( 0, 0, 0, 0.1 );
}

.snld-cmyk__marker {
	position: absolute;
	width: 14px;
	height: 14px;
	margin: -7px 0 0 -7px;
	border-radius: 50%;
	border: 2px solid #fff;
	box-shadow: 0 0 0 1px rgba( 0, 0, 0, 0.5 );
	pointer-events: none;
}

.snld-cmyk__swatches {
	display: grid;
	grid-template-columns: repeat( 6, 1fr );
	gap: 6px;
	margin-bottom: 4px;
}

.snld-cmyk__swatch {
	width: 100%;
	aspect-ratio: 1 / 1;
	min-height: 20px;
	padding: 0;
	border: 1px solid rgba( 0, 0, 0, 0.12 );
	border-radius: 5px;
	cursor: pointer;
}

.snld-cmyk__swatch:hover {
	transform: scale( 1.12 );
	box-shadow: 0 0 0 2px var( --snld-accent );
}

.snld-cmyk {
	max-height: 86vh;
	overflow-y: auto;
}

/* ---------- Palette + pattern carousels ---------- */

.snld-palette-row {
	display: flex;
	align-items: center;
	gap: 10px;
}

/* Pinned "current colour" swatch — always visible at the carousel's left. */
.snld-current-swatch {
	flex: 0 0 auto;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	border: 2px solid #fff;
	box-shadow: 0 0 0 2px var( --snld-accent );
	padding-right: 0;
	margin-right: 4px;
	position: relative;
}

.snld-current-swatch::after {
	content: '';
	position: absolute;
	top: -4px;
	bottom: -4px;
	right: -8px;
	border-right: 1px solid var( --snld-line );
}

.snld-palette {
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	overflow-x: auto;
	padding: 4px 2px 8px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
	flex: 1 1 auto;
	margin: 0;
}

.snld-palette .snld-swatch {
	flex: 0 0 auto;
	scroll-snap-align: start;
}

.snld-pattern-grid {
	display: flex;
	flex-wrap: nowrap;
	gap: 8px;
	overflow-x: auto;
	padding: 4px 2px 10px;
	scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
}

.snld-pattern-grid .snld-pattern-btn {
	flex: 0 0 auto;
	width: 60px;
	scroll-snap-align: start;
}

.snld-palette::-webkit-scrollbar,
.snld-pattern-grid::-webkit-scrollbar {
	height: 7px;
}

.snld-palette::-webkit-scrollbar-thumb,
.snld-pattern-grid::-webkit-scrollbar-thumb {
	background: var( --snld-line );
	border-radius: 999px;
}

/* ---------- Nicer range sliders ---------- */

.snld-app input[ type='range' ] {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	height: 6px;
	margin: 8px 0;
	border-radius: 999px;
	background: var( --snld-line );
	outline: none;
}

.snld-app input[ type='range' ]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var( --snld-accent );
	border: 3px solid #fff;
	box-shadow: 0 1px 4px rgba( 31, 41, 51, 0.3 );
	cursor: pointer;
}

.snld-app input[ type='range' ]::-moz-range-thumb {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var( --snld-accent );
	border: 3px solid #fff;
	box-shadow: 0 1px 4px rgba( 31, 41, 51, 0.3 );
	cursor: pointer;
}

.snld-slider {
	margin-bottom: 14px;
}

/* ---------- Accordion ---------- */

.snld-accordion {
	margin-top: 18px;
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	overflow: hidden;
}

.snld-accordion__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 12px 14px;
	border: 0;
	background: var( --snld-bg );
	font-size: 13.5px;
	font-weight: 700;
	color: var( --snld-ink );
	cursor: pointer;
}

.snld-accordion__chev {
	transition: transform 0.18s ease;
	color: var( --snld-muted );
}

.snld-accordion.is-open .snld-accordion__chev {
	transform: rotate( 180deg );
}

.snld-accordion__body {
	padding: 16px 14px;
}

/* ---------- Pattern code (seed) ---------- */

.snld-seedbox {
	margin-top: 16px;
	padding-top: 14px;
	border-top: 1px solid var( --snld-line );
}

.snld-help {
	font-size: 12px;
	line-height: 1.4;
	color: var( --snld-muted );
	margin: 4px 0 10px;
}

.snld-seedrow {
	display: flex;
	gap: 8px;
	margin-bottom: 8px;
}

.snld-app .snld-seed-input {
	flex: 1 1 auto;
	min-width: 0;
	font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	font-size: 12px;
}

.snld-seedrow .snld-btn {
	width: auto;
	flex: 0 0 auto;
	padding: 8px 14px;
}

/* ---------- CMYK popover: two-column on larger screens ---------- */

.snld-cmyk {
	width: 440px;
	max-width: calc( 100vw - 24px );
	padding: 18px;
}

.snld-cmyk__cols {
	display: flex;
	gap: 18px;
	align-items: flex-start;
}

.snld-cmyk__main {
	flex: 1 1 0;
	min-width: 0;
}

.snld-cmyk__side {
	flex: 0 0 156px;
	min-width: 0;
}

/* Brightness row label is a touch wider than the single C/M/Y/K letters. */
.snld-cmyk__side .snld-cmyk__ch {
	width: 30px;
}

.snld-cmyk__preview {
	height: 48px;
}

@media ( max-width: 540px ) {
	.snld-cmyk {
		width: 280px;
	}

	.snld-cmyk__cols {
		flex-direction: column-reverse;
	}

	.snld-cmyk__side {
		flex: 1 1 auto;
	}

	.snld-cmyk__wheelwrap {
		margin-left: auto;
		margin-right: auto;
	}
}

/* ---------- Arrange (layer order) buttons ---------- */

/* Toolbar above the stage. */
.snld-toolbar {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: nowrap;
	gap: 4px;
	width: 100%;
	max-width: 100%;
	overflow-x: auto;
	margin-bottom: 14px;
	padding: 4px 6px;
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	box-shadow: var( --snld-shadow-sm );
	position: relative;
	z-index: 30;
}

.snld-toolbar::-webkit-scrollbar {
	height: 5px;
}

.snld-toolbar::-webkit-scrollbar-thumb {
	background: var( --snld-line );
	border-radius: 999px;
}

.snld-toolbar__sep {
	width: 1px;
	align-self: stretch;
	background: var( --snld-line );
	margin: 2px 2px;
}

/* Text delete button in the toolbar — a clear red-outlined button.
 * Scoped selector so its auto width beats the 40px .snld-iconbtn rule. */
.snld-toolbar .snld-toolbar__del {
	width: auto;
	min-width: 0;
	padding: 0 11px;
	font-size: 12px;
	font-weight: 700;
	color: #e03131;
	border-color: #f1b0b0;
	background: #fff;
}

.snld-toolbar .snld-toolbar__del:hover {
	border-color: #e03131;
	background: #fff1f1;
	color: #c92a2a;
}

.snld-iconbtn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	flex: 0 0 auto;
	border: 1px solid var( --snld-line );
	background: var( --snld-surface );
	border-radius: 7px;
	font-size: 14px;
	line-height: 1;
	color: var( --snld-ink );
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease, transform 0.06s ease;
}

.snld-fmt-btn.is-on,
.snld-align-btn.is-on {
	border-color: var( --snld-accent );
	background: var( --snld-accent-soft );
	color: var( --snld-accent-dark );
}

.snld-iconbtn svg {
	display: block;
	fill: currentColor;
}

.snld-iconbtn--danger {
	color: #e03131;
}

.snld-iconbtn--danger:hover {
	border-color: #e03131;
	background: #fff5f5;
	color: #c92a2a;
}

.snld-iconbtn:hover {
	border-color: var( --snld-accent );
	background: var( --snld-accent-soft );
	color: var( --snld-accent-dark );
}

.snld-iconbtn:active {
	transform: translateY( 1px );
}

.snld-iconbtn:disabled,
.snld-btn:disabled,
.snld-iconbtn.is-disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

/* Keep the danger bin clearly red even while disabled. */
.snld-iconbtn--danger svg {
	fill: #e03131;
}

/* ---------- Save / load design (local browser) ---------- */

.snld-store {
	margin-top: 18px;
	width: 100%;
	max-width: 420px;
	text-align: center;
}

.snld-store__btns {
	display: flex;
	gap: 10px;
	justify-content: center;
}

.snld-btn--ghost-2 {
	width: auto;
	flex: 1 1 0;
	background: var( --snld-surface );
	color: var( --snld-ink );
	border-color: var( --snld-line );
}

.snld-btn--ghost-2:hover {
	border-color: var( --snld-accent );
	color: var( --snld-accent-dark );
	background: var( --snld-accent-soft );
}

.snld-store__note {
	margin: 10px 0 0;
	font-size: 12px;
	line-height: 1.45;
	color: var( --snld-muted );
}

.snld-store__status {
	margin-top: 6px;
	min-height: 16px;
	font-size: 12.5px;
	font-weight: 600;
	color: var( --snld-accent-dark );
}

/* ---------- Tooltip (JS-positioned, body-level so nothing clips it) ---------- */

.snld-tip {
	position: fixed;
	z-index: 100002;
	background: var( --snld-ink );
	color: #fff;
	font-size: 11.5px;
	font-weight: 600;
	padding: 5px 9px;
	border-radius: 6px;
	white-space: nowrap;
	pointer-events: none;
	box-shadow: 0 4px 14px rgba( 0, 0, 0, 0.25 );
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

.snld-tip[ hidden ] {
	display: none;
}

/* ---------- Saved designs list + random combo ---------- */

.snld-random-btn {
	width: auto;
	margin-top: 10px;
	padding: 8px 16px;
}

.snld-store__list {
	margin-top: 12px;
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.snld-store__row {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 7px 10px;
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: 8px;
}

.snld-store__name {
	flex: 1 1 auto;
	min-width: 0;
	font-size: 13px;
	font-weight: 600;
	color: var( --snld-ink );
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.snld-store__load {
	flex: 0 0 auto;
	border: 1px solid var( --snld-accent );
	background: var( --snld-surface );
	color: var( --snld-accent-dark );
	font-size: 12px;
	font-weight: 600;
	padding: 4px 12px;
	border-radius: 6px;
	cursor: pointer;
}

.snld-store__load:hover {
	background: var( --snld-accent-soft );
}

.snld-store__del {
	flex: 0 0 auto;
	width: 26px;
	height: 26px;
	border: 0;
	background: transparent;
	color: var( --snld-muted );
	font-size: 20px;
	line-height: 1;
	cursor: pointer;
	border-radius: 6px;
}

.snld-store__del:hover {
	background: #fff5f5;
	color: #c92a2a;
}

.snld-store__empty {
	font-size: 12.5px;
	color: var( --snld-muted );
	margin: 2px 0;
}

/* ---------- Pattern sliders: two per row ---------- */

.snld-slider-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6px 16px;
}

.snld-slider-grid .snld-slider {
	margin-bottom: 6px;
}

/* The pinned current-colour swatch is clickable (opens the picker). */
.snld-current-swatch {
	cursor: pointer;
}

/* ---------- Template filter pills: carousel on mobile ---------- */

@media ( max-width: 768px ) {
	.snld-templates__bar {
		flex-direction: column;
		align-items: stretch;
		gap: 8px;
	}

	.snld-templates__filters {
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding-bottom: 4px;
		scroll-snap-type: x proximity;
	}

	.snld-templates__filters .snld-chip {
		flex: 0 0 auto;
		scroll-snap-align: start;
	}

	.snld-templates__filters::-webkit-scrollbar {
		height: 6px;
	}

	.snld-templates__filters::-webkit-scrollbar-thumb {
		background: var( --snld-line );
		border-radius: 999px;
	}
}

/* ---------- Text sub-tabs (Single line / Paragraph) ---------- */

.snld-subtabs {
	display: flex;
	gap: 6px;
	margin-bottom: 14px;
}

.snld-subtab {
	flex: 1 1 0;
	padding: 8px 6px;
	border: 1px solid var( --snld-line );
	background: var( --snld-surface );
	border-radius: var( --snld-radius-sm );
	font-size: 12.5px;
	font-weight: 600;
	color: var( --snld-muted );
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.snld-subtab.is-active {
	background: var( --snld-accent-soft );
	color: var( --snld-accent-dark );
	border-color: var( --snld-accent );
}

.snld-app textarea {
	width: 100%;
	padding: 10px 12px;
	font-size: 14px;
	font-family: inherit;
	color: var( --snld-ink );
	background: var( --snld-surface );
	border: 1px solid var( --snld-line );
	border-radius: var( --snld-radius-sm );
	outline: none;
	resize: vertical;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.snld-app textarea:focus {
	border-color: var( --snld-accent );
	box-shadow: 0 0 0 3px var( --snld-accent-soft );
}

/* ---------- Toolbar alignment tools ---------- */

.snld-toolbar__align {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.snld-toolbar__align[ hidden ] {
	display: none;
}

.snld-align-btn.is-on {
	border-color: var( --snld-accent );
	background: var( --snld-accent-soft );
	color: var( --snld-accent-dark );
}

/* ---------- Headline price / pack / delivery bar ---------- */

.snld-pricebar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 22px;
	margin: 0 0 18px;
	padding: 16px 20px;
	background: linear-gradient( 120deg, var( --snld-header-1 ) 0%, var( --snld-header-2 ) 100% );
	color: #fff;
	border-radius: var( --snld-radius-sm );
	box-shadow: var( --snld-shadow-sm );
}

.snld-pricebar__headline {
	margin: 0;
	display: flex;
	align-items: baseline;
	gap: 10px;
	flex-wrap: wrap;
	line-height: 1.1;
	color: #fff;
}

.snld-pricebar__price {
	font-size: 30px;
	font-weight: 800;
	color: #fff;
}

.snld-pricebar__price .woocommerce-Price-amount,
.snld-pricebar__price bdi {
	color: #fff;
}

.snld-pricebar__pack {
	font-size: 15px;
	font-weight: 600;
	opacity: 0.92;
}

.snld-pricebar__meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px 18px;
	margin-left: auto;
}

.snld-pricebar__meta li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
}

.snld-pricebar__ico {
	font-size: 15px;
	line-height: 1;
}

@media ( max-width: 600px ) {
	.snld-pricebar__meta {
		margin-left: 0;
		width: 100%;
	}
}
