/**
 * Gozero Design Studio — layout aligned with reference mockup.
 */

body.gozero-dt-studio-active .entry-content > *:not(#gozero-studio):not(.gozero-studio),
body.gozero-dt-studio-active .gozero-dt,
body.gozero-dt-studio-active .entry-header,
body.gozero-dt-studio-active .page-header,
body.gozero-dt-studio-active .woocommerce-breadcrumb,
body.gozero-dt-studio-active .elementor-location-header {
	display: none !important;
}

body.gozero-dt-studio-active {
	overflow: hidden !important;
	margin: 0 !important;
	padding: 0 !important;
}

body.gozero-dt-studio-active #page,
body.gozero-dt-studio-active .site,
body.gozero-dt-studio-active .site-content {
	margin: 0 !important;
	padding: 0 !important;
	max-width: none !important;
}

body.admin-bar .gozero-studio {
	top: 32px;
}

@media screen and (max-width: 782px) {
	body.admin-bar .gozero-studio {
		top: 46px;
	}
}

/* Scoped reset — prevents theme/Elementor/WooCommerce from breaking studio controls */
#gozero-studio.gozero-studio,
#gozero-studio.gozero-studio *,
#gozero-studio.gozero-studio *::before,
#gozero-studio.gozero-studio *::after {
	box-sizing: border-box;
}

#gozero-studio.gozero-studio {
	isolation: isolate;
	position: fixed;
	z-index: 999999;
}

#gozero-studio button,
#gozero-studio input,
#gozero-studio select,
#gozero-studio textarea {
	font-family: inherit;
	line-height: 1.4;
	letter-spacing: normal;
	text-transform: none;
	float: none !important;
	clear: none !important;
}

#gozero-studio button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto;
	max-width: none;
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
	color: inherit;
	box-shadow: none;
	text-decoration: none;
	appearance: none;
	-webkit-appearance: none;
	cursor: pointer;
}

#gozero-studio ol,
#gozero-studio ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

#gozero-studio details {
	margin: 0;
}

#gozero-studio summary {
	list-style: none;
	cursor: pointer;
}

#gozero-studio select,
#gozero-studio input[type='text'],
#gozero-studio input[type='number'],
#gozero-studio input[type='color'],
#gozero-studio textarea {
	display: block;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 8px 10px;
	border: 1px solid #d1d5db !important;
	border-radius: 6px !important;
	background: #fff !important;
	color: #111827 !important;
	font-size: 14px !important;
	line-height: 1.4 !important;
	box-shadow: none !important;
	min-height: auto;
}

#gozero-studio input[type='checkbox'] {
	width: 18px !important;
	height: 18px !important;
	min-width: 18px;
	margin: 0;
	padding: 0;
	accent-color: #eb6e28;
}

#gozero-studio label {
	display: block;
	margin: 0;
	font-weight: normal;
}

.gozero-studio {
	--gz-bg: #e8eaed;
	--gz-panel: #fff;
	--gz-border: #d0d5db;
	--gz-blue: #00a3e0;
	--gz-text: #2c2c2c;
	--gz-muted: #6b7280;

	position: fixed;
	inset: 0;
	z-index: 999999;
	display: grid;
	grid-template-columns: 96px 1fr minmax(380px, 460px);
	grid-template-rows: 1fr;
	background: var(--gz-bg);
	font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
	font-size: 14px;
	color: var(--gz-text);
	line-height: 1.4;
}

/* —— Left toolbar —— */
.gozero-studio__toolbar-left {
	grid-column: 1;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: space-between;
	padding: 20px 10px;
	background: #f4f5f7;
	border-right: 1px solid var(--gz-border);
}

.gozero-studio__toolbar-group {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	width: 100%;
}

.gozero-studio__toolbar-group--end {
	margin-top: auto;
}

#gozero-studio .gozero-studio-tool {
	display: flex !important;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100% !important;
	min-height: 56px;
	margin: 0 !important;
	padding: 8px 6px !important;
	border: none !important;
	background: transparent !important;
	border-radius: 4px;
	cursor: pointer;
	color: #444 !important;
	box-shadow: none !important;
}

.gozero-studio-tool:hover,
.gozero-studio-tool:focus-visible {
	background: #e2e6ea;
	outline: none;
}

.gozero-studio-tool__icon {
	display: block;
	width: 1.35em;
	height: 1.35em;
	margin: 0 auto 5px;
	font-size: 20px;
	line-height: 1;
	color: #4b5563;
	font-style: normal;
	font-family: "Font Awesome 6 Free" !important;
	font-weight: 900;
	-webkit-font-smoothing: antialiased;
}

.gozero-studio-tool:hover .gozero-studio-tool__icon,
.gozero-studio-tool:focus-visible .gozero-studio-tool__icon {
	color: var(--gz-blue);
}

.gozero-studio-tool__label {
	font-size: 11px;
	font-weight: 500;
	text-align: center;
	line-height: 1.3;
	text-transform: lowercase;
}

.gozero-studio-tool--hidden {
	display: none !important;
}

/* —— Canvas —— */
.gozero-studio__canvas-area {
	grid-column: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 24px 20px;
	overflow: auto;
	background: linear-gradient(180deg, #dfe3e8 0%, #e8eaed 100%);
}

.gozero-studio__mockup-wrap {
	position: relative;
	width: min(520px, 100%);
	transform-origin: center center;
}

.gozero-studio__mockup-stage {
	position: relative;
	display: block;
	line-height: 0;
}

.gozero-studio__mockup-img {
	display: block;
	width: 100%;
	height: auto;
	pointer-events: none;
	user-select: none;
}

canvas.gozero-studio__mockup-img {
	background: transparent;
}

.gozero-studio__canvas-holder {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	transform: none;
	overflow: visible;
	pointer-events: auto;
	z-index: 2;
}

#gozero-canvas {
	display: block;
}

/* —— Right panel —— */
.gozero-studio__panel {
	grid-column: 3;
	display: flex;
	flex-direction: column;
	min-width: 0;
	background: var(--gz-panel);
	border-left: 1px solid var(--gz-border);
	overflow: hidden;
}

.gozero-studio-tabs {
	display: flex;
	flex-shrink: 0;
	border-bottom: 1px solid var(--gz-border);
	background: #fafbfc;
}

#gozero-studio .gozero-studio-tab {
	flex: 1 1 0;
	min-width: 0;
	min-height: 64px;
	margin: 0 !important;
	padding: 10px 4px 8px !important;
	border: none !important;
	border-right: 1px solid var(--gz-border) !important;
	border-radius: 0 !important;
	background: #fff !important;
	cursor: pointer;
	color: #333 !important;
	text-decoration: none;
	display: flex !important;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: auto !important;
	max-width: none;
	box-shadow: none;
}

.gozero-studio-tab:last-child {
	border-right: none;
}

.gozero-studio-tab__label {
	display: block;
	font-size: 11px;
	font-weight: 600;
	line-height: 1.25;
	word-break: break-word;
}

.gozero-studio-tab.is-active {
	background: #e8f7fc;
	box-shadow: inset 0 -4px 0 var(--gz-blue);
	color: #0077a8;
}

.gozero-studio-tabs--primary {
	flex-wrap: wrap;
}

.gozero-studio-tabs--primary .gozero-studio-tab {
	flex: 1 1 18%;
	min-height: 68px;
	padding: 10px 6px;
}

.gozero-studio-tab__fa {
	display: block;
	font-size: 20px;
	margin-bottom: 6px;
	color: #6b7280;
}

.gozero-studio-tab.is-active .gozero-studio-tab__fa {
	color: var(--gz-blue);
}

.gozero-studio-tabs--secondary {
	display: flex;
	gap: 6px;
	padding: 8px 10px;
	border-bottom: 1px solid var(--gz-border);
	background: #f3f4f6;
}

.gozero-studio-tab-secondary {
	flex: 1;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 6px;
	min-height: 40px;
	margin: 0 !important;
	padding: 8px 10px !important;
	border: 1px solid #d1d5db !important;
	border-radius: 8px !important;
	background: #fff !important;
	color: #374151 !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	cursor: pointer;
}

.gozero-studio-tab-secondary:hover,
.gozero-studio-tab-secondary:focus-visible {
	border-color: var(--gz-blue) !important;
	color: var(--gz-blue) !important;
}

.gozero-studio-tab-secondary.is-active {
	border-color: var(--gz-blue) !important;
	background: #e8f7fc !important;
	color: #0077a8 !important;
	box-shadow: inset 0 0 0 1px var(--gz-blue);
}

.gozero-studio-steps {
	display: flex;
	gap: 4px;
	margin: 0;
	padding: 10px 12px 8px;
	list-style: none;
	background: #fff;
	border-bottom: 1px solid var(--gz-border);
}

.gozero-studio-steps__item {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	font-size: 10px;
	font-weight: 600;
	color: #9ca3af;
	text-align: center;
	line-height: 1.2;
}

.gozero-studio-steps__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #e5e7eb;
	color: #6b7280;
	font-size: 11px;
	font-weight: 700;
}

.gozero-studio-steps__item.is-done .gozero-studio-steps__num {
	background: #d1fae5;
	color: #047857;
}

.gozero-studio-steps__item.is-active {
	color: #111827;
}

.gozero-studio-steps__item.is-active .gozero-studio-steps__num {
	background: var(--gz-blue);
	color: #fff;
}

.gozero-studio-tab--buy {
	background: #eb6e28 !important;
	border-color: #eb6e28 !important;
	color: #fff !important;
	flex: 1.15 1 0;
}

.gozero-studio-tab--buy .gozero-studio-tab__label {
	color: #fff;
	font-weight: 700;
}

.gozero-studio-tab--buy:hover,
.gozero-studio-tab--buy:focus,
.gozero-studio-tab--buy.is-active {
	background: #d45f1f !important;
	border-color: #d45f1f !important;
	color: #fff !important;
}

.gozero-studio-selection-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 0 0 12px;
	padding: 10px 14px;
	background: #f0f6ff;
	border: 1px solid #c7daf5;
	border-radius: 8px;
	flex-shrink: 0;
}

.gozero-studio-selection-bar[hidden] {
	display: none !important;
}

.gozero-studio-selection-bar__label {
	font-size: 13px;
	font-weight: 600;
	color: #1e40af;
}

.gozero-studio-btn--danger {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: auto !important;
	margin: 0 !important;
	padding: 8px 14px !important;
	background: #dc2626 !important;
	border-color: #dc2626 !important;
	color: #fff !important;
}

.gozero-studio-btn--danger:hover,
.gozero-studio-btn--danger:focus-visible {
	background: #b91c1c !important;
	border-color: #b91c1c !important;
	color: #fff !important;
}

.gozero-studio__panel-body {
	flex: 1 1 auto;
	min-height: 0;
	overflow-x: hidden;
	overflow-y: auto;
	padding: 16px 16px 12px;
	-webkit-overflow-scrolling: touch;
}

.gozero-studio-panel {
	display: none;
}

.gozero-studio-panel.is-visible {
	display: block;
}

.gozero-studio-panel__header {
	text-align: center;
	margin-bottom: 20px;
	padding: 0 4px;
}

.gozero-studio-panel__header--left {
	text-align: left;
	padding: 0 16px;
}

.gozero-studio-panel-card--plain {
	border: none;
	background: transparent;
}

.gozero-studio-panel-card--plain .gozero-studio-panel__header {
	border-bottom: none;
	padding-top: 8px;
}

.gozero-studio-panel__title {
	margin: 0 0 6px;
	font-size: 20px;
	font-weight: 700;
	color: var(--gz-text);
	line-height: 1.25;
}

.gozero-studio-panel__subtitle {
	margin: 0;
	font-size: 13px;
	color: var(--gz-muted);
	line-height: 1.4;
}

.gozero-studio-panel__content {
	padding: 0 2px;
}

.gozero-studio-panel-card {
	border: 1px solid var(--gz-border);
	border-radius: 2px;
	background: #fff;
	overflow: hidden;
}

.gozero-studio-panel-card .gozero-studio-panel__header {
	padding: 22px 16px 16px;
	margin-bottom: 0;
	border-bottom: 1px solid var(--gz-border);
}

/* Menu list (reference: row dividers inside card) */
.gozero-studio-menu-list {
	border: none;
	border-radius: 0;
	background: #fff;
	overflow: hidden;
}

#gozero-studio .gozero-studio-menu-item {
	display: flex !important;
	align-items: center;
	width: 100% !important;
	min-width: 0;
	margin: 0 !important;
	padding: 16px 14px !important;
	border: none !important;
	border-bottom: 1px solid var(--gz-border) !important;
	border-radius: 0 !important;
	background: #fff !important;
	cursor: pointer;
	text-align: left;
	gap: 12px;
	box-shadow: none !important;
}

.gozero-studio-menu-item:last-child {
	border-bottom: none;
}

.gozero-studio-menu-item:hover,
.gozero-studio-menu-item:focus-visible {
	background: #f7f9fb;
	outline: none;
}

.gozero-studio-menu-item__text {
	flex: 1;
	min-width: 0;
	overflow: hidden;
}

.gozero-studio-menu-item__text strong {
	display: block;
	font-size: 15px;
	font-weight: 600;
	color: var(--gz-text);
	line-height: 1.3;
	margin-bottom: 3px;
}

.gozero-studio-menu-item__text small {
	display: block;
	font-size: 12px;
	font-weight: 400;
	color: var(--gz-muted);
	line-height: 1.35;
}

.gozero-studio-menu-item__arrow {
	flex-shrink: 0;
	font-size: 20px;
	line-height: 1;
	color: #9ca3af;
	margin-left: 4px;
}

.gozero-studio-menu-item__fa {
	flex-shrink: 0;
	width: 28px;
	font-size: 22px;
	line-height: 1;
	color: var(--gz-blue);
	text-align: center;
	margin-right: 12px;
}

/* Product picker modal (shown on studio load) */
.gozero-product-picker {
	position: fixed;
	inset: 0;
	z-index: 100000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	background: rgba(17, 24, 39, 0.78);
	pointer-events: auto;
}

.gozero-product-picker[hidden] {
	display: none !important;
}

.gozero-product-picker__dialog {
	width: min(1040px, 100%);
	max-height: min(92vh, 800px);
	overflow: auto;
	padding: 32px 36px 36px;
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 28px 60px rgba(0, 0, 0, 0.32);
}

.gozero-product-picker__header {
	text-align: center;
	margin-bottom: 28px;
}

.gozero-product-picker__title {
	margin: 0 0 8px;
	font-size: 28px;
	font-weight: 700;
	color: #111827;
	line-height: 1.2;
}

.gozero-product-picker__subtitle {
	margin: 0 auto;
	max-width: 480px;
	font-size: 15px;
	color: #6b7280;
	line-height: 1.5;
}

.gozero-product-picker__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(140px, 1fr));
	gap: 20px;
	margin: 0 auto;
	max-width: 880px;
}

@media (min-width: 720px) {
	.gozero-product-picker__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.gozero-product-picker__card {
	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	width: 100% !important;
	height: auto !important;
	min-height: 0 !important;
	max-height: none !important;
	margin: 0;
	padding: 0 !important;
	border: 2px solid #e5e7eb;
	border-radius: 12px;
	background: #fff !important;
	cursor: pointer;
	overflow: hidden;
	appearance: none;
	-webkit-appearance: none;
	font: inherit;
	text-align: inherit;
	line-height: inherit;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.gozero-product-picker__card:hover,
.gozero-product-picker__card:focus-visible {
	border-color: #eb6e28;
	outline: none;
	box-shadow: 0 0 0 3px rgba(235, 110, 40, 0.22);
}

.gozero-product-picker__card.is-active {
	border-color: #eb6e28;
	box-shadow: 0 0 0 3px rgba(235, 110, 40, 0.28);
}

/* Fixed-height preview — overrides theme rules on button img */
.gozero-product-picker .gozero-product-picker__img-wrap {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex: 0 0 auto !important;
	width: 100% !important;
	height: 280px !important;
	min-height: 280px !important;
	max-height: 280px !important;
	padding: 16px !important;
	background-color: #d8dee6 !important;
	background-image: linear-gradient(165deg, #e8ecf1 0%, #c5cdd6 100%);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	overflow: hidden;
	box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}

/* Mockup layer sits above a mid-tone stage so light/white products stay visible */
.gozero-product-picker .gozero-product-picker__img-wrap.has-mockup {
	background-color: #6d7888 !important;
	background-repeat: no-repeat, no-repeat;
	background-position: center center, center center;
	background-size: contain, cover;
	box-shadow:
		inset 0 0 0 1px rgba(0, 0, 0, 0.12),
		inset 0 12px 48px rgba(0, 0, 0, 0.14);
}

.gozero-product-picker .gozero-product-picker__img-wrap.has-mockup--tote {
	background-color: #5a6574 !important;
	box-shadow:
		inset 0 0 0 1px rgba(0, 0, 0, 0.16),
		inset 0 16px 56px rgba(0, 0, 0, 0.2);
}

.gozero-product-picker .gozero-product-picker__img-wrap img {
	display: none !important;
	width: 0 !important;
	height: 0 !important;
	max-width: none !important;
	max-height: none !important;
	visibility: hidden !important;
}

.gozero-product-picker .gozero-product-picker__placeholder {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 200px;
	padding: 16px;
	font-size: 14px;
	font-weight: 600;
	color: #9ca3af;
	text-align: center;
}

.gozero-product-picker__label {
	display: block;
	flex-shrink: 0;
	padding: 14px 12px;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	color: #1f2937;
	background: #fff;
	border-top: 1px solid #e5e7eb;
}

.gozero-studio--picker-open .gozero-studio__toolbar-left,
.gozero-studio--picker-open .gozero-studio__canvas-area,
.gozero-studio--picker-open .gozero-studio__panel {
	pointer-events: none;
	user-select: none;
}

/* Design templates modal */
.gozero-templates-modal {
	position: fixed;
	inset: 0;
	z-index: 100001;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	background: rgba(17, 24, 39, 0.78);
	pointer-events: auto;
}

.gozero-templates-modal[hidden] {
	display: none !important;
}

.gozero-templates-modal__dialog {
	position: relative;
	width: min(960px, 100%);
	max-height: min(90vh, 820px);
	display: flex;
	flex-direction: column;
	padding: 28px 32px 32px;
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 28px 60px rgba(0, 0, 0, 0.32);
}

.gozero-templates-modal__header {
	position: relative;
	text-align: center;
	margin-bottom: 20px;
	padding-right: 36px;
}

.gozero-templates-modal__title {
	margin: 0 0 8px;
	font-size: 26px;
	font-weight: 700;
	color: #111827;
}

.gozero-templates-modal__subtitle {
	margin: 0;
	font-size: 15px;
	color: #6b7280;
	line-height: 1.5;
}

.gozero-templates-modal__close {
	position: absolute;
	top: 0;
	right: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 8px;
	background: #f3f4f6;
	color: #374151;
	cursor: pointer;
	font-size: 18px;
}

.gozero-templates-modal__close:hover {
	background: #e5e7eb;
	color: #111827;
}

.gozero-templates-modal__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 16px;
	overflow: auto;
	max-height: min(62vh, 560px);
	padding: 4px;
}

.gozero-templates-modal__empty {
	grid-column: 1 / -1;
	margin: 0;
	padding: 24px;
	text-align: center;
	color: #6b7280;
	font-size: 15px;
}

.gozero-templates-modal__card {
	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	width: 100% !important;
	height: auto !important;
	margin: 0;
	padding: 0 !important;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	background: #fff !important;
	cursor: pointer;
	overflow: hidden;
	appearance: none;
	font: inherit;
	text-align: left;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.gozero-templates-modal__card:hover,
.gozero-templates-modal__card:focus-visible {
	border-color: #eb6e28;
	outline: none;
	box-shadow: 0 0 0 3px rgba(235, 110, 40, 0.2);
}

.gozero-templates-modal__card.is-current {
	border-color: #eb6e28;
}

.gozero-templates-modal .gozero-templates-modal__media {
	display: block !important;
	width: 100% !important;
	height: 150px !important;
	min-height: 150px !important;
	max-height: 150px !important;
	background-color: #f1f4f8 !important;
	background-repeat: no-repeat !important;
	background-position: center center !important;
	background-size: contain !important;
}

.gozero-templates-modal__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 32px;
	font-weight: 700;
	color: #9ca3af;
}

.gozero-templates-modal__label {
	display: block;
	padding: 10px 8px;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.3;
	text-align: center;
	color: #1f2937;
	background: #fff;
	border-top: 1px solid #e5e7eb;
}

.gozero-templates-modal__badge {
	display: inline-block;
	margin-left: 4px;
	padding: 2px 6px;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #fff;
	background: #eb6e28;
	border-radius: 4px;
	vertical-align: middle;
}

.gozero-studio--templates-open .gozero-studio__toolbar-left,
.gozero-studio--templates-open .gozero-studio__canvas-area,
.gozero-studio--templates-open .gozero-studio__panel {
	pointer-events: none;
	user-select: none;
}

.gozero-studio-btn--secondary {
	margin-top: 14px;
	width: 100%;
	background: #fff !important;
	border: 1px solid #d1d5db !important;
	color: #374151 !important;
}

.gozero-studio-btn--secondary:hover {
	border-color: #eb6e28 !important;
	color: #eb6e28 !important;
}

.gozero-studio-product-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin-top: 8px;
}

.gozero-studio-product-card {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 52px;
	padding: 14px 12px;
	margin: 0;
	border: 1px solid #d1d5db;
	border-radius: 6px;
	background: #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
	cursor: pointer;
	font: inherit;
	text-align: center;
	transition:
		border-color 0.15s ease,
		background-color 0.15s ease,
		box-shadow 0.15s ease,
		transform 0.1s ease;
}

.gozero-studio-product-card:hover,
.gozero-studio-product-card:focus-visible {
	border-color: var(--gz-blue);
	background: #f8fafc;
	outline: none;
	box-shadow: 0 2px 6px rgba(37, 99, 235, 0.1);
}

.gozero-studio-product-card:active {
	transform: scale(0.98);
}

.gozero-studio-product-card.is-active {
	border-color: var(--gz-blue);
	border-width: 2px;
	padding: 13px 11px;
	background: #eff6ff;
	box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.15);
}

.gozero-studio-product-card__label {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 1.25em;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.3;
	color: #1f2937;
	text-align: center;
}

.gozero-studio-product-card.is-active .gozero-studio-product-card__label {
	color: var(--gz-blue);
}

.gozero-studio-back {
	margin: 18px 0 0;
	padding: 0;
}

.gozero-studio-back a {
	color: var(--gz-blue);
	text-decoration: none;
	font-size: 13px;
}

.gozero-studio-back a:hover {
	text-decoration: underline;
}

/* Panel action buttons only — not tabs, size controls, or footer */
#gozero-studio .gozero-studio-panel__content > .gozero-studio-btn,
#gozero-studio .gozero-studio-panel__content .gozero-studio-btn--primary,
#gozero-studio .gozero-studio-panel__content .gozero-studio-btn--secondary {
	display: flex;
	width: 100%;
	margin: 0 0 12px;
	padding: 10px 16px;
	text-align: center;
	cursor: pointer;
	border-radius: 6px;
	height: auto;
	line-height: 1.4;
	box-sizing: border-box;
	border: 1px solid #d1d5db;
	background: #fff;
	color: #374151;
	font-size: 14px;
	font-weight: 600;
}

#gozero-studio .gozero-studio-btn--sm {
	display: inline-flex !important;
	width: auto !important;
	margin: 0 !important;
	padding: 8px 14px !important;
}

#gozero-studio .gozero-studio-btn--primary,
#gozero-studio .gozero-studio-panel__content .gozero-studio-btn--primary {
	background: var(--gz-blue) !important;
	border-color: var(--gz-blue) !important;
	color: #fff !important;
	font-weight: 700 !important;
	padding: 14px 16px !important;
}

#gozero-studio .gozero-studio-btn--primary:hover,
#gozero-studio .gozero-studio-panel__content .gozero-studio-btn--primary:hover {
	background: #0088bb !important;
	border-color: #0088bb !important;
	color: #fff !important;
}

.gozero-studio-textarea {
	display: block;
	width: 100%;
	min-height: 120px;
	margin: 0 0 16px;
	padding: 12px 14px;
	border: 1px solid #ccc;
	border-radius: 2px;
	font-size: 15px;
	font-family: inherit;
	line-height: 1.45;
	resize: vertical;
	box-sizing: border-box;
}

.gozero-studio-text-options {
	margin-top: 16px;
	font-size: 13px;
}

.gozero-studio-text-options summary {
	cursor: pointer;
	color: var(--gz-blue);
	font-weight: 600;
	margin-bottom: 12px;
}


/* Add Images panel */
.gozero-studio-panel--images .gozero-studio-panel__content {
	padding: 0 16px 20px;
}

.gozero-studio-images__heading {
	margin: 24px 0 12px;
	font-size: 14px;
	font-weight: 600;
	color: var(--gz-text);
}

.gozero-studio-panel--images .gozero-studio-saved-images {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 10px;
	padding: 0;
	margin: 0 0 8px;
}

.gozero-studio-panel--images .gozero-studio-saved-images__item {
	display: block;
	width: 100%;
	margin: 0;
	padding: 6px;
	border: 1px solid var(--gz-border);
	border-radius: 4px;
	background: #fff;
	cursor: pointer;
}

.gozero-studio-panel--images .gozero-studio-saved-images__item img {
	display: block;
	width: 100%;
	height: auto;
}

.gozero-studio-panel--images .gozero-studio-saved-images__empty {
	padding: 0;
	margin: 0;
	font-size: 13px;
}
.gozero-studio-link-btn {
	display: inline-block;
	background: none;
	border: none;
	color: var(--gz-blue);
	cursor: pointer;
	padding: 10px 0 0;
	margin: 0;
	font-size: 14px;
}

.gozero-studio-hint {
	font-size: 13px;
	color: var(--gz-muted);
	margin: 0 0 14px;
	line-height: 1.45;
}

.gozero-studio-panel label {
	display: block;
	margin-bottom: 14px;
	font-size: 13px;
	font-weight: 600;
	color: var(--gz-text);
}

.gozero-studio-panel input[type="text"],
.gozero-studio-panel select {
	display: block;
	margin-top: 6px;
	width: 100%;
	max-width: 100%;
	padding: 10px 12px;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 14px;
	font-weight: 400;
	background: #fff;
}

.gozero-studio-panel input[type="range"] {
	display: block;
	width: 100%;
	margin-top: 6px;
}

.gozero-studio-panel input[type="color"] {
	margin-top: 6px;
	width: 48px;
	height: 36px;
	padding: 2px;
	border: 1px solid #ccc;
	border-radius: 4px;
	cursor: pointer;
}

/* Sticky quick access: color, sizes, print options */
.gozero-studio-quick-order {
	display: none !important;
}

.gozero-studio-quick-order--legacy {
	flex-shrink: 0;
	margin: 0 0 12px;
	padding: 14px 16px;
	border-radius: 10px;
	background: linear-gradient(135deg, #fff8f3 0%, #ffedd5 100%);
	border: 2px solid #fdba74;
	box-shadow: 0 2px 8px rgba(235, 110, 40, 0.12);
}

.gozero-studio-quick-order[hidden] {
	display: none !important;
}

.gozero-studio-quick-order__title {
	margin: 0 0 10px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #c2410c;
}

.gozero-studio-quick-order__actions {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.gozero-studio-quick-order__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	margin: 0;
	padding: 12px 10px;
	border: 2px solid #fed7aa;
	border-radius: 8px;
	background: #fff;
	color: #9a3412;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.gozero-studio-quick-order__btn:hover,
.gozero-studio-quick-order__btn:focus-visible {
	border-color: #eb6e28;
	color: #eb6e28;
	outline: none;
}

.gozero-studio-quick-order__btn--primary {
	background: #eb6e28;
	border-color: #eb6e28;
	color: #fff;
}

.gozero-studio-quick-order__btn--primary:hover,
.gozero-studio-quick-order__btn--primary:focus-visible {
	background: #d45f1f;
	border-color: #d45f1f;
	color: #fff;
}

.gozero-studio__footer-checkout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.gozero-studio__footer-checkout .gozero-studio__footer-total-box {
	grid-column: 1 / -1;
}

.gozero-studio__footer-checkout .gozero-studio-btn--checkout {
	grid-column: 1 / -1;
}

.gozero-studio__footer-checkout .gozero-studio__footer-hint {
	grid-column: 1 / -1;
}

.gozero-studio-quote__line-amount--discount {
	color: #16a34a;
}

/* Product order blocks (color, sizes) */
.gozero-studio-order-block {
	margin-bottom: 22px;
	padding: 16px;
	border-radius: 10px;
	background: #f8fafc;
	border: 1px solid #e5e7eb;
}

.gozero-studio-order-block--sizes {
	background: #fff8f3;
	border-color: #fdba74;
}

.gozero-studio-order-block__title {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 10px;
	font-size: 15px;
	font-weight: 700;
	color: #111827;
	letter-spacing: 0.02em;
}

.gozero-studio-order-block__title i {
	color: #eb6e28;
	font-size: 16px;
	width: 1.25em;
	text-align: center;
}

.gozero-studio-quote__section-title {
	display: flex;
	align-items: center;
	gap: 8px;
}

.gozero-studio-quote__section-title i,
.gozero-studio-quote__breakdown-title i {
	color: #eb6e28;
	font-size: 14px;
}

.gozero-studio-quote__breakdown-title {
	display: flex;
	align-items: center;
	gap: 8px;
}

.gozero-studio-quote__field--full {
	grid-column: 1 / -1;
}

.gozero-studio-order-block__desc {
	margin: 0 0 12px;
	font-size: 13px;
	color: #6b7280;
	line-height: 1.4;
}

.gozero-studio-swatches {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 0;
}

.gozero-studio-swatches--product {
	gap: 12px;
}

#gozero-studio .gozero-studio-swatch {
	width: 40px !important;
	height: 40px !important;
	min-width: 40px;
	margin: 0 !important;
	padding: 0 !important;
	border-radius: 50% !important;
	border: 2px solid #fff !important;
	box-shadow: 0 0 0 1px #ccc, 0 2px 4px rgba(0, 0, 0, 0.08);
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
	display: inline-block !important;
}

.gozero-studio-swatches--product .gozero-studio-swatch {
	width: 44px;
	height: 44px;
}

.gozero-studio-swatch:hover {
	transform: scale(1.08);
}

.gozero-studio-swatch.is-active {
	box-shadow: 0 0 0 3px var(--gz-blue), 0 2px 6px rgba(0, 136, 187, 0.35);
}

/* Per-size quantity cards */
.gozero-size-qty-table-wrap {
	margin: 0 0 12px;
	border-radius: 10px;
	border: 1px solid #e5e7eb;
	background: #f9fafb;
	padding: 8px;
}

.gozero-size-qty-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.gozero-size-qty-card {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 12px;
	margin: 0 !important;
	padding: 12px 14px !important;
	border-radius: 10px;
	background: #fff;
	border: 1px solid #e5e7eb;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.gozero-size-qty-card__meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 4.5rem;
}

.gozero-size-qty-card__size,
.gozero-size-qty-row__size {
	font-size: 17px;
	font-weight: 800;
	color: #111827;
	line-height: 1.2;
}

.gozero-size-qty-card__price,
.gozero-size-qty-row__price {
	font-size: 13px;
	font-weight: 600;
	color: #6b7280;
}

.gozero-size-qty-card__controls,
.gozero-size-qty-row__controls {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	justify-content: flex-end !important;
	gap: 6px !important;
	flex-shrink: 0;
}

#gozero-studio .gozero-size-qty-btn {
	flex: 0 0 36px;
	display: inline-flex !important;
	width: 36px !important;
	height: 36px !important;
	min-width: 36px;
	margin: 0 !important;
	padding: 0 !important;
	border: 2px solid #d1d5db !important;
	border-radius: 8px !important;
	background: #f9fafb !important;
	color: #374151 !important;
	font-size: 20px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	cursor: pointer;
	box-shadow: none !important;
	transition: background 0.15s ease, border-color 0.15s ease;
}

.gozero-size-qty-btn:hover {
	background: #fff;
	border-color: #eb6e28;
	color: #eb6e28;
}

.gozero-size-qty-input {
	width: 56px !important;
	min-width: 56px;
	height: 36px !important;
	margin: 0 !important;
	padding: 0 6px !important;
	border: 2px solid #d1d5db !important;
	border-radius: 8px !important;
	font-size: 16px !important;
	font-weight: 700 !important;
	text-align: center !important;
	color: #111827 !important;
	background: #fff !important;
	box-sizing: border-box !important;
}

.gozero-size-qty-input:focus {
	outline: none;
	border-color: #eb6e28;
	box-shadow: 0 0 0 2px rgba(235, 110, 40, 0.25);
}

.gozero-size-qty-summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 14px;
	padding: 12px 14px;
	border-radius: 8px;
	background: #fff;
	border: 2px solid #eb6e28;
}

.gozero-size-qty-summary__label {
	font-size: 13px;
	font-weight: 600;
	color: #6b7280;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.gozero-size-qty-summary__value {
	font-size: 22px;
	font-weight: 700;
	color: #eb6e28;
}

.gozero-studio-quote__field--sizes {
	grid-column: 1 / -1;
}

.gozero-studio-quote__field-label {
	display: block;
	margin-bottom: 4px;
	font-size: 14px;
	font-weight: 700;
	color: #111827;
}

.gozero-studio__footer-meta-sizes {
	display: block;
	margin-top: 4px;
	font-size: 12px;
	font-weight: 500;
	color: #6b7280;
	line-height: 1.35;
}

.gozero-studio-status {
	font-size: 13px;
	color: #2e7d32;
	min-height: 1.2em;
	margin: 0 0 8px;
}

/* Footer inside right panel */
.gozero-studio__footer {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 0;
	padding: 14px 16px 16px;
	background: #f4f5f7;
	border-top: 2px solid #d1d5db;
	box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.06);
	position: relative;
	z-index: 5;
}

.gozero-studio__footer-product {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding-bottom: 10px;
	border-bottom: 1px solid #d1d5db;
}

.gozero-studio__footer-meta-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #6b7280;
}

.gozero-studio__footer-meta-value {
	font-size: 13px;
	font-weight: 600;
	color: #1f2937;
	line-height: 1.35;
}

.gozero-studio__footer-total-box {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 14px;
	border-radius: 8px;
	background: #fff;
	border: 1px solid #e5e7eb;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.gozero-studio__footer-total-label {
	font-size: 14px;
	font-weight: 600;
	color: #374151;
}

.gozero-studio__footer-total-amount {
	font-size: 26px;
	font-weight: 800;
	line-height: 1;
	color: #eb6e28;
	letter-spacing: -0.02em;
}

.gozero-studio__footer--checkout {
	padding-top: 14px;
}

#gozero-studio .gozero-studio__footer .gozero-studio-btn--checkout {
	display: flex !important;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100% !important;
	margin: 0 !important;
	padding: 14px 18px !important;
	border: none !important;
	border-radius: 10px !important;
	background: #eb6e28 !important;
	color: #fff !important;
	font-size: 16px !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	box-shadow: 0 4px 14px rgba(235, 110, 40, 0.38);
	transition: background 0.15s ease, box-shadow 0.15s ease;
}

.gozero-studio-btn--checkout:hover,
.gozero-studio-btn--checkout:focus {
	background: #d45f1f !important;
	color: #fff !important;
	box-shadow: 0 6px 18px rgba(235, 110, 40, 0.45);
}

.gozero-studio-btn--checkout:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.gozero-studio-btn--options {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	margin: 0 !important;
	padding: 10px 14px !important;
	border: 1px solid #d1d5db !important;
	border-radius: 8px !important;
	background: #fff !important;
	color: #374151 !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	line-height: 1.2 !important;
	cursor: pointer;
	transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}

.gozero-studio-btn--options:hover,
.gozero-studio-btn--options:focus {
	border-color: #eb6e28 !important;
	color: #eb6e28 !important;
	background: #fff8f4 !important;
}

.gozero-studio-btn--options.is-active {
	border-color: #eb6e28 !important;
	background: #fff3eb !important;
	color: #c45a1a !important;
	box-shadow: inset 0 0 0 1px #eb6e28;
}

.gozero-studio__footer-hint {
	margin: 0;
	text-align: center;
	font-size: 12px;
	color: #b32d2e;
}

/* Quote / order panel */
.gozero-studio-panel-card--quote .gozero-studio-panel__content {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.gozero-studio-quote__section {
	margin-bottom: 14px;
}

.gozero-studio-quote .gozero-studio-quote__section:last-child {
	margin-bottom: 0;
}

.gozero-studio-quote__section-title {
	margin: 0 0 12px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #6b7280;
}

.gozero-studio-order-block--sizes-panel {
	margin-bottom: 20px;
}

.gozero-studio-quote__options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 14px;
}

.gozero-studio-quote__options--order {
	margin-bottom: 0;
}

.gozero-studio-quote__sides {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.gozero-studio-quote__side-card {
	display: flex !important;
	align-items: flex-start;
	gap: 12px;
	margin: 0;
	padding: 14px;
	border: 2px solid #e5e7eb;
	border-radius: 10px;
	background: #fff;
	cursor: pointer;
	font: inherit;
	text-align: left;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.gozero-studio-quote__side-card input[type='checkbox'] {
	width: 20px;
	height: 20px;
	margin: 2px 0 0;
	flex-shrink: 0;
	accent-color: #eb6e28;
	cursor: pointer;
}

.gozero-studio-quote__side-card:has(input:checked) {
	border-color: #eb6e28;
	box-shadow: 0 0 0 3px rgba(235, 110, 40, 0.15);
}

.gozero-studio-quote__side-card-body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
	min-width: 0;
}

.gozero-studio-quote__side-card-body strong {
	font-size: 15px;
	color: #111827;
}

.gozero-studio-quote__side-card-body small {
	font-size: 12px;
	font-weight: 500;
	color: #6b7280;
	line-height: 1.4;
}

.gozero-studio-quote__field--inline {
	display: flex;
	flex-direction: row !important;
	align-items: center;
	gap: 10px;
	margin: 0 !important;
}

.gozero-studio-quote__field--inline span {
	flex-shrink: 0;
}

.gozero-studio-quote__field--inline select {
	flex: 1;
	min-width: 0;
	margin: 0 !important;
}

.gozero-studio-quote__back-highlight {
	padding: 14px;
	border-radius: 12px;
	border: 2px dashed #eb6e28;
	background: linear-gradient(135deg, #fff8f4 0%, #ffedd5 100%);
	box-shadow: 0 0 0 3px rgba(235, 110, 40, 0.12);
	transition: opacity 0.2s ease, filter 0.2s ease;
}

.gozero-studio-quote__back-highlight.is-available {
	animation: gozero-back-pulse 2.5s ease-in-out infinite;
}

.gozero-studio-quote__back-highlight.is-disabled {
	opacity: 0.45;
	filter: grayscale(0.2);
	animation: none;
	pointer-events: none;
}

.gozero-studio-quote__back-highlight:has(#gozero-order-print-back:checked) {
	border-style: solid;
	border-color: #eb6e28;
	background: linear-gradient(135deg, #fff3eb 0%, #fed7aa 100%);
	animation: none;
}

.gozero-studio-quote__back-callout {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 10px;
	font-size: 14px;
	font-weight: 700;
	color: #c2410c;
}

.gozero-studio-quote__back-callout i {
	font-size: 18px;
}

.gozero-studio-quote__side-card--back {
	border-color: #fdba74;
	background: #fff;
}

.gozero-studio-quote__field.is-collapsed {
	display: none !important;
}

.gozero-studio-quote__panel-note {
	margin: 12px 0 0;
	padding-top: 10px;
	border-top: 1px dashed #ddd;
	font-size: 13px;
	color: #6b7280;
	line-height: 1.45;
}

@keyframes gozero-back-pulse {
	0%,
	100% {
		box-shadow: 0 0 0 3px rgba(235, 110, 40, 0.12);
	}
	50% {
		box-shadow: 0 0 0 6px rgba(235, 110, 40, 0.22);
	}
}

.gozero-studio-quote__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-size: 13px;
}

.gozero-studio-quote__field span {
	font-weight: 600;
	color: #333;
}

.gozero-studio-quote__field input,
.gozero-studio-quote__field select {
	width: 100%;
	max-width: 100%;
	padding: 8px 10px;
	border: 1px solid var(--gz-border);
	border-radius: 6px;
	font-size: 14px;
}

.gozero-studio-quote__check {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	grid-column: 1 / -1;
	margin: 0;
	cursor: pointer;
}

.gozero-studio-quote__check input {
	width: auto;
	margin: 0;
}

.gozero-studio-quote__breakdown {
	border: 1px solid var(--gz-border);
	border-radius: 8px;
	padding: 14px;
	background: #f8f9fa;
}

.gozero-studio-quote__breakdown-title {
	margin: 0 0 10px;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #444;
}

.gozero-studio-quote__lines {
	list-style: none;
	margin: 0 0 12px;
	padding: 0;
}

.gozero-studio-quote__line {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 12px;
	padding: 6px 0;
	border-bottom: 1px dashed #ddd;
	font-size: 13px;
}

.gozero-studio-quote__line:last-child {
	border-bottom: none;
}

.gozero-studio-quote__line-label {
	color: #555;
}

.gozero-studio-quote__line-amount {
	font-weight: 600;
	white-space: nowrap;
}

.gozero-studio-quote__totals {
	border-top: 2px solid #ddd;
	padding-top: 10px;
}

.gozero-studio-quote__total-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 14px;
	padding: 4px 0;
}

.gozero-studio-quote__total-row--grand {
	margin-top: 6px;
	padding-top: 10px;
	border-top: 1px solid #ccc;
	font-size: 16px;
	font-weight: 700;
}

.gozero-studio-quote__total-row--grand strong {
	color: #eb6e28;
	font-size: 18px;
}

.gozero-studio-btn--cart {
	width: 100%;
	justify-content: center;
	padding: 12px 16px !important;
	font-size: 15px !important;
	font-weight: 700 !important;
}

.gozero-studio-quote__hint {
	color: #b32d2e;
	margin: 0;
}

@media (max-width: 1100px) {
	.gozero-studio {
		grid-template-columns: 80px 1fr minmax(280px, 340px);
	}
}

@media (max-width: 900px) {
	.gozero-studio {
		grid-template-columns: 72px 1fr;
		grid-template-rows: 1fr auto;
	}

	.gozero-studio__panel {
		grid-column: 1 / -1;
		grid-row: 2;
		max-height: 48vh;
	}

	.gozero-studio__toolbar-left {
		flex-direction: column;
		padding: 12px 8px;
	}

	.gozero-studio-tool {
		min-height: 40px;
		padding: 6px 4px;
	}

	.gozero-studio-tab {
		min-height: 60px;
	}

	.gozero-studio-tab__label {
		font-size: 10px;
	}
}

/* Canvas view tabs & print area */
.gozero-studio__canvas-area {
	align-items: center;
}

.gozero-studio__view-tabs {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	gap: 8px;
	width: 100%;
	max-width: 520px;
	margin: 0 auto 8px;
	order: 0;
}

#gozero-studio .gozero-studio__view-tab {
	display: inline-flex !important;
	flex: 0 0 auto;
	align-items: center;
	gap: 8px;
	min-height: 40px;
	width: auto !important;
	margin: 0 !important;
	padding: 8px 18px !important;
	border: 2px solid #cbd5e1 !important;
	border-radius: 999px !important;
	background: #fff !important;
	color: #374151 !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	cursor: pointer;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

#gozero-studio .gozero-studio__view-tab.is-active {
	border-color: var(--gz-blue) !important;
	background: #e8f7fc !important;
	color: #0077a8 !important;
}

.gozero-studio__mockup-wrap {
	order: 1;
	margin: 0 auto;
}

.gozero-studio__mockup-wrap {
	filter: drop-shadow(0 10px 28px rgba(0, 0, 0, 0.14));
}

.gozero-studio__print-area {
	position: absolute;
	z-index: 3;
	pointer-events: none;
	border: 2px dashed rgba(0, 163, 224, 0.9);
	border-radius: 6px;
	box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.5) inset;
}

.gozero-studio__canvas-holder::after {
	content: '';
	position: absolute;
	top: var(--gz-print-top, 22%);
	left: var(--gz-print-left, 26%);
	width: var(--gz-print-width, 48%);
	height: var(--gz-print-height, 38%);
	border: 2px dashed rgba(0, 163, 224, 0.55);
	border-radius: 4px;
	pointer-events: none;
	z-index: 4;
}

.gozero-studio__canvas-hint {
	margin: 0;
	font-size: 13px;
	color: #6b7280;
	text-align: center;
	max-width: 520px;
}

.gozero-studio__canvas-hint i {
	margin-right: 6px;
	color: var(--gz-blue);
}

/* Summary card & accordions */
.gozero-studio-summary-card {
	margin-bottom: 14px;
	padding: 14px 16px;
	border-radius: 12px;
	background: linear-gradient(135deg, #fff8f4 0%, #fff 100%);
	border: 1px solid #fed7aa;
}

.gozero-studio-summary-card__title {
	margin: 0 0 10px;
	font-size: 15px;
	font-weight: 700;
	color: #111827;
}

.gozero-studio-summary-card__list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px 16px;
	margin: 0;
}

.gozero-studio-summary-card__list dt {
	margin: 0;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #9ca3af;
}

.gozero-studio-summary-card__list dd {
	margin: 2px 0 0;
	font-size: 14px;
	font-weight: 600;
	color: #1f2937;
}

.gozero-studio-accordion {
	margin-bottom: 10px;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	background: #fff;
	overflow: hidden;
}

.gozero-studio-accordion__summary {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 16px;
	font-size: 15px;
	font-weight: 700;
	color: #111827;
	cursor: pointer;
	list-style: none;
}

.gozero-studio-accordion__summary::-webkit-details-marker {
	display: none;
}

.gozero-studio-accordion__summary::after {
	content: '+';
	margin-left: auto;
	font-size: 18px;
	font-weight: 700;
	color: #9ca3af;
}

.gozero-studio-accordion[open] .gozero-studio-accordion__summary::after {
	content: '−';
	color: var(--gz-blue);
}

.gozero-studio-accordion[open] .gozero-studio-accordion__summary {
	background: #f8fafc;
	border-bottom: 1px solid #e5e7eb;
}

.gozero-studio-accordion__body {
	padding: 14px 16px 16px;
}

.gozero-studio-btn--block {
	display: flex !important;
	width: 100%;
	margin-top: 12px !important;
}

.gozero-studio-link-inline {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0;
	padding: 0;
	border: none;
	background: none;
	color: var(--gz-blue);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	text-decoration: underline;
}

.gozero-studio-checkout-intro {
	margin: 0 0 12px;
}

.gozero-studio-quote__total-line {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin: 12px 0 0;
	padding-top: 12px;
	border-top: 2px solid #e5e7eb;
	font-size: 15px;
	font-weight: 600;
}

.gozero-studio-quote__total-line strong {
	font-size: 22px;
	color: #eb6e28;
}

.gozero-studio__footer-meta-compact {
	display: block;
	font-size: 13px;
	font-weight: 500;
	color: #6b7280;
	text-align: center;
}

.gozero-studio__footer-links {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	flex-wrap: wrap;
}

.gozero-size-qty-btn,
.gozero-size-qty-input {
	float: none !important;
	display: inline-flex !important;
	vertical-align: middle !important;
}
