/**
 * Canvas3D Customizer — public stylesheet (Phase 6 redesign)
 *
 * Layout: sizes on top → big 2D editor (with bleed + cut lines + "View in 3D"
 * button) → adjustments toolbar + filters → warnings → confirm bar.
 * The 3D viewer opens as a 90%-screen lightbox.
 */

.c3dc-configurator {
	--c3dc-primary: #0073aa;
	--c3dc-primary-dark: #005f8a;
	--c3dc-text: #1a1f24;
	--c3dc-text-muted: #6b7280;
	--c3dc-border: #e5e7eb;
	--c3dc-surface: #f8fafc;
	--c3dc-surface-2: #f1f3f6;
	--c3dc-bg: #ffffff;
	--c3dc-radius: 14px;
	--c3dc-radius-sm: 8px;
	--c3dc-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
	--c3dc-shadow: 0 6px 24px -8px rgba(15, 23, 42, 0.18);
	--c3dc-shadow-lg: 0 18px 50px -12px rgba(15, 23, 42, 0.35);

	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, Helvetica, Arial, sans-serif;
	color: var(--c3dc-text);
	background: var(--c3dc-bg);
	border-radius: var(--c3dc-radius);
	box-shadow: var(--c3dc-shadow);
	margin: 18px auto;
	width: 100%;
	max-width: 1080px;
	overflow: hidden;
	box-sizing: border-box;
}

.c3dc-configurator *,
.c3dc-configurator *::before,
.c3dc-configurator *::after {
	box-sizing: border-box;
}

/* ============================================================
   Empty / loading / status states
   ============================================================ */
.c3dc-empty,
.c3dc-loading-placeholder {
	padding: 60px 24px;
	text-align: center;
	color: var(--c3dc-text-muted);
	font-size: 14px;
}

.c3dc-status {
	padding: 12px 18px;
	border-radius: var(--c3dc-radius-sm);
	font-size: 13px;
	margin: 14px 24px;
}
.c3dc-status.is-loading {
	background: rgba(0, 115, 170, 0.08);
	color: var(--c3dc-primary-dark);
}
.c3dc-status.is-error {
	background: #fef2f2;
	color: #991b1b;
}

/* ============================================================
   Upload screen
   ============================================================ */
.c3dc-app-upload {
	padding: 24px;
}

.c3dc-upload-zone {
	border: 2px dashed var(--c3dc-border);
	border-radius: var(--c3dc-radius);
	padding: 60px 24px;
	text-align: center;
	background: var(--c3dc-surface);
	cursor: pointer;
	transition: all 0.18s ease;
	min-height: 280px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.c3dc-upload-zone:hover,
.c3dc-upload-zone.is-dragging {
	background: rgba(0, 115, 170, 0.04);
	border-color: var(--c3dc-primary);
}
.c3dc-upload-zone.is-uploading {
	cursor: progress;
	opacity: 0.75;
}
.c3dc-upload-icon { font-size: 42px; margin-bottom: 14px; }
.c3dc-upload-title { font-size: 18px; font-weight: 600; margin-bottom: 6px; }
.c3dc-upload-sub { font-size: 14px; color: var(--c3dc-text-muted); margin-bottom: 18px; }
.c3dc-upload-formats {
	font-size: 12px;
	letter-spacing: 0.4px;
	color: var(--c3dc-text-muted);
	text-transform: uppercase;
}

/* ============================================================
   Main layout (post-upload)
   ============================================================ */
.c3dc-layout-v2 {
	display: flex;
	flex-direction: column;
}

.c3dc-section {
	padding: 22px 28px;
}
.c3dc-section + .c3dc-section {
	border-top: 1px solid var(--c3dc-border);
}

/* ── Section 1: sizes bar (top, horizontal) ─────────────────── */
.c3dc-sizes-bar {
	background: var(--c3dc-surface);
}

/* Grouped picker: each group has a title and one or two orientations
   on the SAME row (Vertical [sizes] Horizontal [sizes]). */
.c3dc-picker {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.c3dc-picker-bar {
	gap: 18px;
}

.c3dc-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.c3dc-group-title {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.2px;
	color: var(--c3dc-text-muted);
	margin: 0;
}
.c3dc-group-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
}
.c3dc-group-row-orientation {
	padding: 4px 0;
}
.c3dc-group-row-orientation + .c3dc-group-row-orientation {
	border-top: 1px dashed var(--c3dc-border);
	margin-top: 2px;
	padding-top: 8px;
}
.c3dc-group-subtitle {
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.8px;
	color: var(--c3dc-text-muted);
	white-space: nowrap;
	min-width: 76px;
}

.c3dc-size {
	border: 1.5px solid #3a3a3a;
	background: #1e1e1e;
	border-radius: 10px;
	padding: 10px 18px;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	cursor: pointer;
	transition: all 0.18s ease;
	font: inherit;
	min-height: 56px;
	min-width: 100px;
	color: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,0.25);
}
.c3dc-size:hover {
	border-color: #555;
	background: #2a2a2a;
}
.c3dc-size.is-active {
	background: linear-gradient(180deg, #d4a017 0%, #b8870b 100%);
	border-color: #b8870b;
	color: #111;
	box-shadow: 0 2px 6px rgba(180, 130, 0, 0.45);
}
.c3dc-size-dims {
	font-weight: 700;
	font-size: 14px;
	color: inherit;
	letter-spacing: 0.2px;
}
.c3dc-size-price {
	font-size: 12px;
	font-weight: 500;
	color: inherit;
	opacity: 0.85;
}
.c3dc-size.is-active .c3dc-size-dims,
.c3dc-size.is-active .c3dc-size-price {
	color: #111;
	opacity: 1;
}

/* ── Section 2: stage (big 2D editor) ───────────────────────── */
.c3dc-stage {
	display: flex;
	flex-direction: column;
	align-items: center;
	background: linear-gradient(180deg, #fafbfc 0%, #f4f6f8 100%);
	padding-top: 28px;
	padding-bottom: 12px;
}

.c3dc-adjustments {
	display: flex;
	flex-direction: column;
	gap: 18px;
	background: var(--c3dc-bg);
	padding-top: 6px;
}

.c3dc-canvas-wrap {
	position: relative;
	display: inline-block;
	border-radius: var(--c3dc-radius-sm);
	overflow: hidden;
	box-shadow: 0 10px 30px -8px rgba(15, 23, 42, 0.25);
	background: #ececec;
}
.c3dc-canvas {
	display: block;
	cursor: grab;
}
.c3dc-canvas:active { cursor: grabbing; }

.c3dc-view-3d-btn {
	position: absolute;
	top: 12px;
	right: 12px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: rgba(15, 23, 42, 0.85);
	color: #fff;
	border: none;
	border-radius: 999px;
	cursor: pointer;
	font: inherit;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.3px;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	transition: all 0.18s ease;
	box-shadow: 0 6px 18px -4px rgba(15, 23, 42, 0.35);
}
.c3dc-view-3d-btn:hover {
	background: var(--c3dc-primary);
	transform: translateY(-1px);
	box-shadow: 0 10px 22px -4px rgba(0, 115, 170, 0.45);
}
.c3dc-view-3d-icon {
	display: inline-block;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: rgba(255,255,255,0.2);
	text-align: center;
	line-height: 18px;
	font-size: 13px;
}

/* Cut-line legend under the canvas */
.c3dc-cut-legend {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 14px;
	font-size: 12px;
	color: var(--c3dc-text-muted);
}
.c3dc-cut-legend-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.c3dc-cut-legend-line {
	display: inline-block;
	width: 26px;
	height: 0;
	border-top-width: 2px;
	border-top-style: solid;
	font-style: normal;
}
.c3dc-cut-line-inner { border-top-style: dashed; border-color: #e53935; }
.c3dc-cut-line-outer { border-top-style: dashed; border-color: rgba(229,57,53,0.6); }
.c3dc-cut-legend-bottom {
	padding: 14px 16px;
	border-top: 1px solid var(--c3dc-border);
	margin-top: 0;
	background: var(--c3dc-bg);
}
.c3dc-cut-legend-hint {
	flex-basis: 100%;
	text-align: center;
	font-size: 11px;
	color: var(--c3dc-text-muted);
	font-style: italic;
	margin-top: 2px;
}

/* ── Section 3: adjustments toolbar + filters ───────────────── */
.c3dc-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
	padding: 12px;
	background: var(--c3dc-surface);
	border-radius: 999px;
	border: 1px solid var(--c3dc-border);
	width: fit-content;
	margin: 0 auto;
}

.c3dc-tool {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	border: none;
	background: var(--c3dc-bg);
	color: var(--c3dc-text);
	cursor: pointer;
	font: inherit;
	font-size: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.15s ease;
	box-shadow: var(--c3dc-shadow-sm);
}
.c3dc-tool:hover {
	background: var(--c3dc-primary);
	color: #fff;
}
.c3dc-tool.is-active {
	background: var(--c3dc-primary);
	color: #fff;
}

/* Capture buttons (Grabar vídeo / Captura PNG) — pill-shaped with text. */
.c3dc-tool-rec,
.c3dc-tool-snap {
	width: auto;
	border-radius: 999px;
	padding: 0 16px;
	font-size: 13px;
	font-weight: 600;
	gap: 6px;
	white-space: nowrap;
}
.c3dc-tool-snap:hover {
	background: #1e1e1e !important;
	color: #fff !important;
}
.c3dc-tool-rec {
	background: #dc2626 !important;
	color: #fff !important;
}
.c3dc-tool-rec:hover {
	background: #b91c1c !important;
	color: #fff !important;
}
.c3dc-tool-rec.is-recording {
	background: #dc2626 !important;
	color: #fff !important;
	animation: c3dc-rec-pulse 1.4s ease-in-out infinite;
}
.c3dc-tool-rec.is-recording:hover {
	background: #b91c1c !important;
}
.c3dc-rec-progress {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.c3dc-rec-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #fff;
	animation: c3dc-rec-blink 0.9s ease-in-out infinite;
}
@keyframes c3dc-rec-blink {
	0%, 100% { opacity: 1; }
	50%      { opacity: 0.3; }
}
@keyframes c3dc-rec-pulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.55); }
	50%      { box-shadow: 0 0 0 8px rgba(220, 38, 38, 0); }
}

/* Filter panel */
.c3dc-filter-panel {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	padding: 18px;
	background: var(--c3dc-surface);
	border-radius: var(--c3dc-radius);
	border: 1px solid var(--c3dc-border);
}
@media (min-width: 720px) {
	.c3dc-filter-panel {
		grid-template-columns: 1fr 1.4fr auto;
		align-items: start;
	}
}

.c3dc-presets {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.c3dc-preset {
	padding: 8px 12px;
	border: 1.5px solid var(--c3dc-border);
	background: var(--c3dc-bg);
	border-radius: 999px;
	font: inherit;
	font-size: 12px;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.15s ease;
}
.c3dc-preset:hover { border-color: var(--c3dc-primary); }
.c3dc-preset.is-active {
	background: var(--c3dc-primary);
	color: #fff;
	border-color: var(--c3dc-primary);
}

.c3dc-sliders {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px 18px;
}
@media (max-width: 480px) {
	.c3dc-sliders { grid-template-columns: 1fr; }
}

.c3dc-slider {
	display: flex;
	flex-direction: column;
	gap: 5px;
	font-size: 12px;
}
.c3dc-slider-lbl {
	display: flex;
	justify-content: space-between;
	color: var(--c3dc-text-muted);
	font-weight: 500;
}
.c3dc-slider-lbl em {
	font-style: normal;
	color: var(--c3dc-text);
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}
.c3dc-slider input[type="range"] {
	width: 100%;
	accent-color: var(--c3dc-primary);
}

.c3dc-filter-footer {
	display: flex;
	flex-direction: column;
	gap: 10px;
	align-items: flex-start;
}

.c3dc-checkbox {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	cursor: pointer;
}

.c3dc-link {
	background: none;
	border: none;
	color: var(--c3dc-primary);
	cursor: pointer;
	font: inherit;
	font-size: 13px;
	padding: 0;
	text-decoration: underline;
}
.c3dc-link:hover { color: var(--c3dc-primary-dark); }

.c3dc-change-image {
	align-self: center;
	background: none;
	border: 1px solid var(--c3dc-border);
	border-radius: 999px;
	padding: 8px 18px;
	color: var(--c3dc-text-muted);
	font: inherit;
	font-size: 13px;
	cursor: pointer;
	transition: all 0.15s ease;
}
.c3dc-change-image:hover {
	color: var(--c3dc-primary);
	border-color: var(--c3dc-primary);
}

/* ── Warnings ───────────────────────────────────────────────── */
.c3dc-warnings {
	padding: 12px 28px 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.c3dc-warning {
	padding: 10px 14px;
	border-radius: var(--c3dc-radius-sm);
	font-size: 13px;
	background: #fffbeb;
	color: #92400e;
	border-left: 4px solid #f59e0b;
}
.c3dc-warning-error {
	background: #fef2f2;
	color: #991b1b;
	border-left-color: #dc2626;
}
.c3dc-warning-icon { margin-right: 6px; }

/* ── Quality badge (traffic light: green / yellow / red) ────── */
.c3dc-quality {
	margin: 12px 28px 0;
	padding: 10px 14px;
	border-radius: var(--c3dc-radius-sm);
	font-size: 14px;
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: 10px;
	border-left: 4px solid;
}
.c3dc-quality-dot {
	display: inline-block;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	flex-shrink: 0;
}
.c3dc-quality-msg {
	line-height: 1.4;
	font-weight: 600 !important;
}
.c3dc-quality-green {
	background: #d1fae5;
	color: #064e3b !important;
	border-left-color: #059669;
}
.c3dc-quality-green .c3dc-quality-msg { color: #064e3b !important; }
.c3dc-quality-green .c3dc-quality-dot { background: #059669; }

.c3dc-quality-yellow {
	background: #fef3c7;
	color: #78350f !important;
	border-left-color: #d97706;
}
.c3dc-quality-yellow .c3dc-quality-msg { color: #78350f !important; }
.c3dc-quality-yellow .c3dc-quality-dot { background: #d97706; }

.c3dc-quality-red {
	background: #fee2e2;
	color: #7f1d1d !important;
	border-left-color: #dc2626;
}
.c3dc-quality-red .c3dc-quality-msg { color: #7f1d1d !important; }
.c3dc-quality-red .c3dc-quality-dot { background: #dc2626; }

/* ── Confirm bar ────────────────────────────────────────────── */
.c3dc-confirm-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 28px 24px;
	background: var(--c3dc-bg);
	border-top: 1px solid var(--c3dc-border);
	flex-wrap: wrap;
}
.c3dc-price {
	display: flex;
	flex-direction: column;
}
.c3dc-price-lbl {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--c3dc-text-muted);
}
.c3dc-price-num {
	font-size: 26px;
	font-weight: 700;
}
.c3dc-confirm-btn {
	background: var(--c3dc-primary);
	color: #fff;
	border: none;
	border-radius: var(--c3dc-radius-sm);
	padding: 14px 28px;
	font: inherit;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.15s ease;
	box-shadow: var(--c3dc-shadow);
}
.c3dc-confirm-btn:hover:not(:disabled) {
	background: var(--c3dc-primary-dark);
	transform: translateY(-1px);
}
.c3dc-confirm-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* ── 3D Lightbox ────────────────────────────────────────────── */
.c3dc-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: c3dc-fade-in 0.2s ease;
}
@keyframes c3dc-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}
.c3dc-lightbox-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.7);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	cursor: pointer;
}
.c3dc-lightbox-window {
	position: relative;
	width: 90vw;
	height: 90vh;
	background: linear-gradient(180deg, #ffffff 0%, #f4f6f8 100%);
	border-radius: 18px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	box-shadow: var(--c3dc-shadow-lg);
	animation: c3dc-zoom-in 0.22s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes c3dc-zoom-in {
	from { transform: scale(0.95); opacity: 0; }
	to   { transform: scale(1);    opacity: 1; }
}

.c3dc-lightbox-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 20px;
	background: rgba(255, 255, 255, 0.85);
	border-bottom: 1px solid var(--c3dc-border);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}
.c3dc-lightbox-header h3 {
	margin: 0;
	font-size: 16px;
	font-weight: 600;
	color: var(--c3dc-text);
}
.c3dc-lightbox-close {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: none;
	background: var(--c3dc-surface-2);
	color: var(--c3dc-text);
	cursor: pointer;
	font: inherit;
	font-size: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.15s ease;
}
.c3dc-lightbox-close:hover {
	background: var(--c3dc-primary);
	color: #fff;
	transform: rotate(90deg);
}

.c3dc-lightbox-body {
	flex: 1;
	min-height: 0;
	display: flex;
	flex-direction: column;
	padding: 16px;
}

/* ── 3D viewer (inside the lightbox) ────────────────────────── */
.c3dc-viewer-wrap {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 12px;
	min-height: 0;
	width: 100%;
}
.c3dc-viewer-stage {
	flex: 1 1 0;
	min-height: 0;       /* lets it shrink so siblings stay visible */
	border-radius: var(--c3dc-radius);
	background: linear-gradient(180deg, #fafbfc 0%, #eaecef 100%);
	overflow: hidden;
	width: 100%;
}
.c3dc-viewer-controls {
	display: flex;
	gap: 8px;
	justify-content: center;
	padding: 8px;
	background: rgba(255, 255, 255, 0.9);
	border-radius: 999px;
	border: 1px solid var(--c3dc-border);
	align-self: center;
	box-shadow: var(--c3dc-shadow-sm);
	flex: 0 0 auto;       /* always visible, never compressed */
}
.c3dc-viewer-hint {
	font-size: 12px;
	color: var(--c3dc-text-muted);
	text-align: center;
	letter-spacing: 0.3px;
	flex: 0 0 auto;
}

/* ── Resize handles overlay on the canvas ─────────────────── */
.c3dc-handles {
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.c3dc-handle {
	position: absolute;
	width: 14px;
	height: 14px;
	margin-left: -7px;
	margin-top: -7px;
	background: #fff;
	border: 2px solid var(--c3dc-primary);
	border-radius: 50%;
	box-shadow: 0 1px 4px rgba(0,0,0,0.35);
	pointer-events: auto;
	cursor: nwse-resize;
	touch-action: none;
	transition: transform 0.12s ease, background 0.12s ease;
}
.c3dc-handle:hover { transform: scale(1.25); background: var(--c3dc-primary); }
.c3dc-handle-n,  .c3dc-handle-s  { cursor: ns-resize; }
.c3dc-handle-w,  .c3dc-handle-e  { cursor: ew-resize; }
.c3dc-handle-nw, .c3dc-handle-se { cursor: nwse-resize; }
.c3dc-handle-ne, .c3dc-handle-sw { cursor: nesw-resize; }

/* Lock-aspect tool active state */
.c3dc-tool-lock.is-active {
	background: var(--c3dc-primary);
	color: #fff;
}

/* ── Transform panel (free X/Y scaling) ─────────────────────── */
.c3dc-transform-panel {
	padding: 14px 18px;
	background: var(--c3dc-surface);
	border-radius: var(--c3dc-radius);
	border: 1px solid var(--c3dc-border);
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.c3dc-transform-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
}
.c3dc-transform-lock {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	cursor: pointer;
	user-select: none;
	color: var(--c3dc-text-muted);
}
.c3dc-transform-lock input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}
.c3dc-transform-lock-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--c3dc-bg);
	border: 1.5px solid var(--c3dc-border);
	font-size: 13px;
	transition: all 0.15s ease;
}
.c3dc-transform-lock input:checked + .c3dc-transform-lock-icon {
	background: var(--c3dc-primary);
	color: #fff;
	border-color: var(--c3dc-primary);
}
.c3dc-transform-lock-lbl { font-weight: 500; }

.c3dc-transform-sliders {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px 18px;
}
@media (max-width: 480px) {
	.c3dc-transform-sliders { grid-template-columns: 1fr; }
}

/* ── Cut-line legend (extra variant for lateral/back lines) ── */
.c3dc-cut-line-lateral { border-top-style: dashed; border-color: #e53935; }
.c3dc-cut-line-back    { border-top-style: dashed; border-color: rgba(229,57,53,0.6); }

/* ── Shortcode embed ────────────────────────────────────────── */
.c3dc-configurator-shortcode {
	width: 100%;
	max-width: 100%;
	margin: 24px 0;
}

/* ── Responsive tweaks ──────────────────────────────────────── */
@media (max-width: 640px) {
	.c3dc-section { padding: 18px 16px; }
	.c3dc-confirm-bar { padding: 14px 16px 20px; }
	.c3dc-confirm-btn { width: 100%; }
	.c3dc-picker-bar { gap: 16px; }
	.c3dc-stage { padding-top: 18px; padding-bottom: 18px; }

	/* Keep the lightbox at 90% on mobile too (user request), and shrink the
	   header padding so the 3D + controls + hint all fit. */
	.c3dc-lightbox-window { width: 90vw; height: 90vh; border-radius: 14px; }
	.c3dc-lightbox-header { padding: 10px 14px; }
	.c3dc-lightbox-header h3 { font-size: 14px; }
	.c3dc-lightbox-close { width: 32px; height: 32px; }
	.c3dc-lightbox-body { padding: 10px; gap: 8px; }
	.c3dc-viewer-wrap { gap: 8px; }
	.c3dc-viewer-controls { padding: 6px; }
	.c3dc-viewer-controls .c3dc-tool { width: 36px; height: 36px; font-size: 16px; }
	.c3dc-viewer-hint { font-size: 11px; }
}
@media (max-width: 380px) {
	.c3dc-viewer-hint { display: none; } /* hide hint on very small screens */
}
