/*
 * sueco Custom Designer — Frontend-Styles (Phase 3 Block E Etappe 3).
 *
 * Mobile-First. Desktop-Refit greift ab 768 px Viewport-Breite und
 * schaltet den Wizard-Body in ein zweispaltiges Workspace-Layout.
 *
 * Token-Konsum (ADR-17): Plugin verbraucht die globalen Theme-Tokens
 * aus dem Blocksy Child Theme (`--sueco-primary`, `--sueco-text-*`,
 * `--sueco-bg-cream`, `--sueco-border` etc., definiert in
 * `blocksy-child/assets/css/brand.css`). Die Fallback-Hex-Werte
 * spiegeln die Theme-Defaults 1:1, damit das Plugin auch ohne aktives
 * Theme keine fremden Markenfarben rendert. Plugin pflegt KEIN eigenes
 * `--sueco-color-*`-Token-Set parallel — bei Erweiterungsbedarf wird
 * das Website-Design-System ergänzt.
 */

/* Etappe-2-Smoke-Finding 2: Modal saß ~15 px nach links versetzt, weil
 * der Scrollbar-Streifen aus 100vw nicht rausgerechnet wurde. Mit
 * `scrollbar-gutter: stable` reserviert der Browser den Gutter immer,
 * Modal sitzt exakt mittig. Greift auf das gesamte Dokument — kein
 * Plugin-spezifischer Selektor, weil Wizard `display: flex` mit
 * `width: 100vw` braucht. */
html {
	scrollbar-gutter: stable;
}

/* Body-Scroll-Lock, solange der Designer-<dialog> offen ist (Editor.open()
   setzt/entfernt die Klasse). showModal() macht den Hintergrund nur für
   Klick/Fokus inert, NICHT fürs Wheel-Scrollen — ohne Lock scrollt die
   Seite hinter dem Modal mit (Smoke 2026-05-29 Desktop). Lock greift auf
   <html> (das scrollende Wurzelelement); `scrollbar-gutter: stable` oben
   hält den Gutter-Platz, daher kein Layout-Shift beim Sperren. */
html.sueco-designer-scroll-lock {
	overflow: hidden;
}

/* Etappe-3.1-Smoke-Finding F-E-9: Text-Selektion war im Cream-Theme
 * praktisch unsichtbar, weil der Browser-Default-Highlight kaum Kontrast
 * gegen Input-BG und Modal-BG bietet. Wir setzen den Marken-Braunton als
 * Selektions-BG mit weißem Foreground — funktioniert auf Cream-Modal,
 * weißen Inputs und Snapshot-Bereich gleichermaßen. Scope nur Modal +
 * Trigger, damit die Plugin-Regel nicht in den Rest der Seite ausstrahlt. */
.sueco-designer-modal ::selection,
.sueco-designer-trigger::selection {
	background: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-white, #ffffff);
}

/* -----------------------------------------------------------------
   Trigger („Jetzt personalisieren"-Button auf der Produktseite).
   ----------------------------------------------------------------- */

.sueco-designer-trigger {
	display: inline-block;
	padding: 0.85rem 1.4rem;
	border: none;
	border-radius: 999px;
	background: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-white, #ffffff);
	font: inherit;
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
}

.sueco-designer-trigger:hover,
.sueco-designer-trigger:focus-visible {
	background: var(--sueco-primary-hover, #704930);
	outline: none;
}

/* Hydration-Lock — Trigger startet ausgegraut, bis GET /state durch ist.
 * Hooks gesetzt aus `index.js` (`dataset.hydrating`, `dataset.hydrationError`).
 */
.sueco-designer-trigger[data-hydrating="true"] {
	opacity: 0.65;
	cursor: progress;
}

.sueco-designer-trigger[data-hydration-error] {
	opacity: 0.55;
	cursor: not-allowed;
}

/* Wartungs-Hinweis statt Designer-UI bei fehlendem Vorschau-Asset
 * (ADR-26 + Datenmodell §7.5.4). Greift im Frontend als Hard-Block,
 * solange `_sueco_preview_svg_id` leer ist. */
.sueco-designer-maintenance {
	margin: 1.2rem 0;
	padding: 1rem 1.2rem;
	border-radius: 8px;
	border: 1px solid var(--sueco-border, #e7e5e4);
	background: var(--sueco-bg-cream, #fbf6ec);
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-maintenance p {
	margin: 0;
}

.sueco-designer-maintenance p + p {
	margin-top: 0.4rem;
	color: var(--sueco-text-secondary, #57534e);
}

/* -----------------------------------------------------------------
   Zusammenfassungs-Karte (G4.5) — erscheint statt des Triggers, sobald
   die Personalisierung „übernommen" wurde: Mini-Vorschau + Bestätigung +
   „Bearbeiten". Nach „Übernehmen" führt highlightNativeCart() zum nativen
   Warenkorb-Button.
   ----------------------------------------------------------------- */

.sueco-designer-summary {
	display: flex;
	gap: 1rem;
	align-items: center;
	margin: 1.2rem 0;
	padding: 0.9rem 1rem;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
	background: var(--sueco-bg-cream, #fbf6ec);
}

.sueco-designer-summary__media {
	flex: 0 0 auto;
	width: 64px;
	height: 64px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	border-radius: 8px;
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
}

.sueco-designer-summary__thumb {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.sueco-designer-summary__media--placeholder {
	color: var(--sueco-primary, #8b5e3c);
	font-size: 1.6rem;
	font-weight: 700;
}

.sueco-designer-summary__body {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	min-width: 0;
}

.sueco-designer-summary__heading {
	margin: 0;
	font-weight: 600;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-summary__summary {
	margin: 0;
	font-size: 0.9rem;
	color: var(--sueco-text-secondary, #57534e);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sueco-designer-summary__edit {
	align-self: flex-start;
	margin-top: 0.35rem;
	padding: 0.35rem 0.9rem;
	border: 1px solid var(--sueco-primary, #8b5e3c);
	border-radius: 999px;
	background: transparent;
	color: var(--sueco-primary, #8b5e3c);
	font: inherit;
	font-weight: 600;
	cursor: pointer;
}

.sueco-designer-summary__edit:hover,
.sueco-designer-summary__edit:focus-visible {
	background: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-white, #ffffff);
	outline: none;
}

/* Kurz-Hervorhebung des nativen Warenkorb-Buttons nach „Übernehmen"
   (highlightNativeCart). Bei reduzierter Bewegung kein Puls — die Klasse
   wird per Timeout-Fallback in index.js trotzdem wieder entfernt. */
@keyframes sueco-designer-cart-pulse {
	0% { box-shadow: 0 0 0 0 rgba(139, 94, 60, 0.5); }
	70% { box-shadow: 0 0 0 12px rgba(139, 94, 60, 0); }
	100% { box-shadow: 0 0 0 0 rgba(139, 94, 60, 0); }
}

.sueco-designer-cart-highlight {
	animation: sueco-designer-cart-pulse 1.2s ease-out 2;
}

@media (prefers-reduced-motion: reduce) {
	.sueco-designer-cart-highlight {
		animation: none;
	}
}

/* -----------------------------------------------------------------
   Modal-Frame.
   ----------------------------------------------------------------- */

.sueco-designer-modal {
	width: 100vw;
	max-width: 100vw;
	/* G4-θ-Mobile-Fix (Julio 2026-05-31): `100dvh` statt `100vh`. `100vh` ist
	   die GROSSE Viewport-Höhe (gerechnet, als wäre die Browser-URL-Leiste
	   bereits ausgeblendet) — bei sichtbarer URL-Leiste ragt der Dialog dann
	   unten dahinter und die sticky `bottom:0`-CTA-Leiste verschwindet hinter
	   der Adressleiste („In den Warenkorb" überdeckt, bis man scrollt). `dvh`
	   misst die TATSÄCHLICH sichtbare Höhe und folgt der ein-/ausfahrenden
	   URL-Leiste live. `vh` bleibt als Fallback für Engines ohne dvh. */
	height: 100vh;
	height: 100dvh;
	max-height: 100vh;
	max-height: 100dvh;
	margin: 0;
	padding: 0;
	border: none;
	background: var(--sueco-bg-cream, #fbf6ec);
	color: var(--sueco-text-primary, #2d2926);
}

/* Display-Layout NUR im offenen Zustand — `display: flex` ohne diese
 * Bedingung überschreibt das User-Agent-Default
 * `dialog:not([open]) { display: none }`. */
.sueco-designer-modal[open] {
	display: flex;
	flex-direction: column;
}

.sueco-designer-modal::backdrop {
	background: rgba(28, 28, 28, 0.55);
}

/* -----------------------------------------------------------------
   Topbar (sticky).
   ----------------------------------------------------------------- */

.sueco-designer-modal__bar {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	background: var(--sueco-bg-cream, #fbf6ec);
	border-bottom: 1px solid var(--sueco-border, #e7e5e4);
	position: sticky;
	top: 0;
	z-index: 2;
	flex: 0 0 auto;
}

.sueco-designer-modal__title {
	flex: 1;
	font-family: var(--sueco-font-body, "Inter", system-ui, sans-serif);
	font-size: 15px;
	font-weight: 600;
	margin: 0;
}

.sueco-designer-modal__back,
.sueco-designer-modal__close {
	width: 32px;
	height: 32px;
	background: transparent;
	border: none;
	font-size: 18px;
	line-height: 1;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	cursor: pointer;
	color: inherit;
}

.sueco-designer-modal__back:hover,
.sueco-designer-modal__close:hover {
	background: var(--sueco-bg-gray, #f4f4f5);
}

.sueco-designer-modal__back[hidden] {
	visibility: hidden;
	display: inline-flex;
}

/* -----------------------------------------------------------------
   Progress (sticky unter Topbar).
   ----------------------------------------------------------------- */

.sueco-designer-modal__progress {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 16px 12px;
	background: var(--sueco-bg-cream, #fbf6ec);
	border-bottom: 1px solid var(--sueco-border, #e7e5e4);
	position: sticky;
	top: 49px; /* Topbar-Höhe (Padding 12 + Inhalt ~25 + Padding 12) */
	z-index: 1;
	flex: 0 0 auto;
}

.sueco-designer-modal__progress-track {
	flex: 1;
	height: 4px;
	background: var(--sueco-border, #e7e5e4);
	border-radius: 999px;
	overflow: hidden;
}

.sueco-designer-modal__progress-fill {
	height: 100%;
	background: var(--sueco-primary, #8b5e3c);
	transition: width 200ms ease-out;
	width: 0%;
	border-radius: inherit;
}

.sueco-designer-modal__progress-label {
	font-size: 11px;
	font-weight: 600;
	color: var(--sueco-text-secondary, #57534e);
	letter-spacing: 0.04em;
	min-width: 36px;
	text-align: right;
}

/* -----------------------------------------------------------------
   Body — Mobile column, Desktop row.
   ----------------------------------------------------------------- */

.sueco-designer-modal__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-height: 0;
}

.sueco-designer-modal__content {
	flex: 1;
	min-width: 0;
	overflow-y: auto;
	padding: 20px 16px 24px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

/* -----------------------------------------------------------------
   Stage-Pane (Live-Preview, fester DOM-Slot — Spur 3).
   Mobile: Preview-Card oben (white, border, radius); Desktop: linke
   Spalte 45 %, transparent. `data-show-stage="false"` am Body
   blendet die Pane aus (service-type-Step).
   ----------------------------------------------------------------- */

.sueco-designer-stage-pane {
	flex: 0 0 auto;
	margin: 16px 16px 0;
	padding: 16px;
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	position: relative;
}

.sueco-designer-stage-pane__container {
	width: 100%;
	max-width: 280px;
	/* aspect-ratio wird per JS aus den Produkt-Postmeta-Maßen gesetzt
	 * (Wizard.ensureStage). Fallback hier: quadratisch. */
	aspect-ratio: 1 / 1;
}

.sueco-designer-stage-pane__caption {
	font-size: 10px;
	color: var(--sueco-text-secondary, #57534e);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	align-self: flex-end;
}

.sueco-designer-modal__body[data-show-stage="false"] .sueco-designer-stage-pane {
	display: none;
}

/* -----------------------------------------------------------------
   Bottombar (sticky).
   ----------------------------------------------------------------- */

.sueco-designer-modal__bottombar {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 12px 16px calc(18px + env(safe-area-inset-bottom));
	background: var(--sueco-bg-cream, #fbf6ec);
	border-top: 1px solid var(--sueco-border, #e7e5e4);
	position: sticky;
	bottom: 0;
	z-index: 2;
	flex: 0 0 auto;
}

.sueco-designer-modal__bottombar:empty {
	display: none;
}

.sueco-designer-modal__bottombar-row {
	display: flex;
	gap: 10px;
	width: 100%;
}

.sueco-designer-modal__bottombar--stack .sueco-designer-modal__bottombar-row {
	flex-direction: column;
}

/* -----------------------------------------------------------------
   Desktop-Refit (≥ 768 px).
   ----------------------------------------------------------------- */

@media (min-width: 768px) {
	.sueco-designer-modal {
		/* G4-θ (Julio 2026-05-31): Fenster großzügiger — die rechte Bedien-
		   Spalte trägt jetzt Inhalt + Schrift + Position/Größe + Ebenen-Liste
		   und braucht mehr Höhe, damit alles ohne Scrollen sichtbar ist. */
		width: min(1040px, 92vw);
		max-width: 92vw;
		height: min(800px, 92vh);
		max-height: 92vh;
		margin: auto;
		border-radius: 20px;
		overflow: hidden;
	}

	.sueco-designer-modal__body {
		flex-direction: row;
	}

	/* 4a.1.2 — Stage-Pane auf Desktop wieder als weißer Container (wie
	   Mobile). Julio-Feedback 2026-05-19 abend: einheitlich mit den
	   Font-/Input-Cards. ~20 px margin zum Modal-Rand, gleiche Border-/
	   Radius-Tokens wie die Cards. Padding bleibt 24 px für inneren
	   Atemraum. */
	.sueco-designer-stage-pane {
		flex: 0 0 calc(45% - 30px);
		max-width: calc(45% - 30px);
		margin: 20px 0 20px 20px;
		padding: 24px;
		justify-content: center;
	}

	.sueco-designer-stage-pane__container {
		max-width: 100%;
	}

	.sueco-designer-modal__content {
		flex: 1;
		padding: 24px;
	}

	/* Bug 1 (4a.1): adjust-Step bricht das 45/55-Zweispalten-Layout,
	   weil die rechte Spalte dort nur Heading + Hint zeigt — der User
	   sieht eine links versetzte Stage und einen halbleeren Rest. Im
	   adjust-Step wird der Body stattdessen vertikal gestapelt:
	   Stage-Pane oben mit zentriertem Container, Heading + Hint
	   darunter. Stage-Mitte trifft so die Modal-Mitte. */
	.sueco-designer-modal__body[data-active-step="adjust"] {
		flex-direction: column;
	}
	.sueco-designer-modal__body[data-active-step="adjust"] .sueco-designer-stage-pane {
		flex: 0 0 auto;
		width: calc(100% - 40px);
		max-width: calc(100% - 40px);
		margin: 20px 20px 0 20px;
		padding: 24px;
	}
	.sueco-designer-modal__body[data-active-step="adjust"] .sueco-designer-stage-pane__container {
		max-width: 480px;
	}
	.sueco-designer-modal__body[data-active-step="adjust"] .sueco-designer-modal__content {
		flex: 1;
		padding-top: 8px;
		text-align: center;
	}
}

/* -----------------------------------------------------------------
   Step-Content-Bausteine (Spur 4 — globale Typo + Form-Polish).
   ----------------------------------------------------------------- */

.sueco-designer-step {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

/* Heading auf Playfair 22 px 600 — Markenstimme (brand.css §Headings).
 * Greift für alle vier Steps; Step-spezifische Größen werden nicht
 * benötigt. */
.sueco-designer-step__heading {
	font-family: var(--sueco-font-heading, "Playfair Display", Georgia, serif);
	font-size: 22px;
	font-weight: 600;
	line-height: 1.2;
	margin: 0;
	color: var(--sueco-text-primary, #2d2926);
}

/* Hinweis-Paragraph unter dem Heading — kommt im AdjustStep zum Tragen
 * (Phase 4 Block F Etappe 4a), wo die Stage-Pane das eigentliche
 * Interaktions-Surface ist und der Content-Bereich nur den Hinweis
 * trägt. */
.sueco-designer-step__hint {
	margin: 0;
	font-size: 14px;
	line-height: 1.5;
	color: var(--sueco-text-secondary, #57534e);
}

/* 4a.1.1: Stage-Pane-Clamp-Flash + Persistent-Caption-Marker entfernt
 * (Julio-Feedback 2026-05-19). Die Item-eigene rote Dash-Outline aus
 * ContentLayer.buildClampOutline bleibt als subtiler Affordance-Marker. */

.sueco-designer-step__fields {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.sueco-designer-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sueco-designer-field__label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-field__label-optional {
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
	opacity: 0.7;
}

.sueco-designer-field__input {
	font: inherit;
	min-height: 48px;
	padding: 11px 13px;
	border: 2px solid var(--sueco-border, #e7e5e4);
	border-radius: 8px;
	background: var(--sueco-white, #ffffff);
	color: var(--sueco-text-primary, #2d2926);
	transition: border-color 150ms ease-out;
}

.sueco-designer-field__input::placeholder {
	color: var(--sueco-text-secondary, #57534e);
	opacity: 0.5;
}

/* 4a.1.3 — Specificity-Bump gegen Blocksys Theme-Forms-Regel
 * `input:is([type="text"], ...)` (0,1,1) für Default und
 * `input:is([type="text"], ...):focus` (0,2,1) für Focus.
 * Wrapper-Selector `.sueco-designer-modal` hebt uns auf (0,2,0)
 * default und (0,3,0) focus, sodass weiß-Background, 2-px-Border
 * und Primary-Border-Color im Fokus durchschlagen.
 *
 * `:focus` statt `:focus-visible`: bei Mausklick auf Inputs ist
 * `:focus-visible` zwar äquivalent, aber `:focus` greift auch bei
 * programmatischem `.focus()`-Aufruf und vermeidet Browser-
 * Sonderfälle. Für Inputs ist das harmlos (Outline-Affordance bei
 * Keyboard-Nav wird durch den Border-Color-Wechsel ersetzt). */
.sueco-designer-modal .sueco-designer-field__input {
	border: 2px solid var(--sueco-border, #e7e5e4);
	background-color: var(--sueco-white, #ffffff);
}

.sueco-designer-modal .sueco-designer-field__input:focus {
	outline: none;
	border-color: var(--sueco-primary, #8b5e3c);
	background-color: var(--sueco-white, #ffffff);
}

.sueco-designer-link {
	align-self: flex-start;
	background: transparent;
	border: none;
	color: var(--sueco-primary, #8b5e3c);
	font: inherit;
	padding: 0;
	cursor: pointer;
	text-decoration: underline;
}

.sueco-designer-link[hidden] {
	display: none;
}

/* -----------------------------------------------------------------
   Buttons (Spur 4 — 48-px-Refit, Ghost-Block-Variante neu).
   ----------------------------------------------------------------- */

.sueco-designer-button {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font: inherit;
	font-size: 15px;
	font-weight: 600;
	min-height: 48px;
	padding: 12px 18px;
	border-radius: 8px;
	border: none;
	cursor: pointer;
	line-height: 1.2;
}

.sueco-designer-button:focus-visible {
	outline: 2px solid var(--sueco-primary, #8b5e3c);
	outline-offset: 2px;
}

.sueco-designer-button__icon {
	width: 18px;
	height: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: inherit;
}

.sueco-designer-button__icon svg {
	width: 100%;
	height: 100%;
}

.sueco-designer-button--primary {
	background: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-white, #ffffff);
}

.sueco-designer-button--primary:hover:not(:disabled) {
	background: var(--sueco-primary-hover, #704930);
}

.sueco-designer-button--primary:disabled {
	background: var(--sueco-border, #e7e5e4);
	color: var(--sueco-text-secondary, #57534e);
	cursor: not-allowed;
}

.sueco-designer-button--secondary {
	background: transparent;
	color: var(--sueco-text-primary, #2d2926);
	border: 1px solid var(--sueco-border, #e7e5e4);
}

.sueco-designer-button--secondary:hover {
	background: var(--sueco-bg-gray, #f4f4f5);
}

/* Ghost-Block — full-width, dashed Border, für „+ Zeile hinzufügen"
 * im EnterTextsStep. Hat keine Solid-BG, nur einen dezenten Outline-
 * Look, damit es nicht mit den Primary-/Secondary-Bottombar-Buttons
 * konkurriert. */
.sueco-designer-button--ghost-block {
	flex: 0 0 auto;
	width: 100%;
	background: transparent;
	color: var(--sueco-text-secondary, #57534e);
	border: 1px dashed var(--sueco-border, #e7e5e4);
	font-weight: 500;
}

.sueco-designer-button--ghost-block:hover:not(:disabled) {
	border-color: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-button--ghost-block[hidden] {
	display: none;
}

/* -----------------------------------------------------------------
   Service-Type-Cards (Spur 4 — Icon-Pill + Eyebrow + Pill-Preis).
   Card-Grid: [Icon-Pill] [Body-Col mit Eyebrow/Title/Text] [Price-Pill].
   Pro-Card ist disabled, behält aber den vollen Look mit reduzierter
   Opacity — UX-Mockup §02 Service-Type.
   ----------------------------------------------------------------- */

.sueco-designer-card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 6px;
	padding: 16px;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
	background: var(--sueco-white, #ffffff);
	font: inherit;
	text-align: left;
	cursor: pointer;
	transition: border-color 150ms ease-out;
}

.sueco-designer-card:hover:not(:disabled),
.sueco-designer-card:focus-visible:not(:disabled) {
	border-color: var(--sueco-primary, #8b5e3c);
	outline: none;
}

.sueco-designer-card:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

/* Service-Card-Variante: Grid mit Icon links, Body-Col mitte,
 * Price-Pill rechts oben. */
.sueco-designer-card--service {
	display: grid;
	grid-template-columns: 44px 1fr auto;
	grid-template-rows: auto;
	column-gap: 14px;
	row-gap: 6px;
	align-items: start;
}

.sueco-designer-card__icon {
	grid-column: 1;
	grid-row: 1;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--sueco-bg-cream, #fbf6ec);
	color: var(--sueco-primary, #8b5e3c);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.sueco-designer-card__icon svg {
	width: 22px;
	height: 22px;
}

.sueco-designer-card__body-col {
	grid-column: 2;
	grid-row: 1;
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.sueco-designer-card__eyebrow {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-card__title {
	font-family: var(--sueco-font-heading, "Playfair Display", Georgia, serif);
	font-weight: 600;
	font-size: 18px;
	line-height: 1.25;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-card__text {
	font-size: 13px;
	line-height: 1.45;
	color: var(--sueco-text-secondary, #57534e);
}

/* Price-Pill: rechts oben, kompakter Pill mit Variante neutral (grau,
 * für „Inklusive") und accent (brown, für „+ 17,50 €"). */
.sueco-designer-card__price-pill {
	grid-column: 3;
	grid-row: 1;
	align-self: start;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.4;
	white-space: nowrap;
}

.sueco-designer-card__price-pill--neutral {
	background: var(--sueco-bg-cream, #fbf6ec);
	color: var(--sueco-text-secondary, #57534e);
	border: 1px solid var(--sueco-border, #e7e5e4);
}

.sueco-designer-card__price-pill--accent {
	background: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-white, #ffffff);
}

/* -----------------------------------------------------------------
   Banner (Tipp-Hinweis im ServiceTypeStep, Spur 4).
   ----------------------------------------------------------------- */

.sueco-designer-banner {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 12px 14px;
	border-radius: 10px;
	font-size: 13px;
	line-height: 1.4;
}

.sueco-designer-banner--info {
	background: var(--sueco-bg-cream, #fbf6ec);
	border: 1px solid var(--sueco-border, #e7e5e4);
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-banner__icon {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	display: inline-flex;
	color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-banner__icon svg {
	width: 100%;
	height: 100%;
}

.sueco-designer-banner__text {
	flex: 1;
}

/* -----------------------------------------------------------------
   Font-Cards (Spur 4 — Custom-Radio-Pill).
   Natives <input type=radio> bleibt aus A11y-Gründen, wird aber visuell
   versteckt und durch einen 18-px-Custom-Radio ersetzt. :checked-State
   blendet eine „gewählt"-Pill rechts ein.
   ----------------------------------------------------------------- */

.sueco-designer-font-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.sueco-designer-font-card {
	position: relative;
	display: grid;
	grid-template-columns: 18px 1fr auto;
	column-gap: 14px;
	align-items: center;
	padding: 13px 15px;
	border: 2px solid var(--sueco-border, #e7e5e4);
	border-radius: 10px;
	background: var(--sueco-white, #ffffff);
	cursor: pointer;
	transition: border-color 150ms ease-out, background-color 150ms ease-out;
}

.sueco-designer-font-card:hover {
	border-color: var(--sueco-primary, #8b5e3c);
}

/* Natives Radio absolut positionieren + visuell unsichtbar, aber an der
 * Custom-Radio-Position, damit Klick/Focus auf den Custom-Radio den
 * nativen Input erreicht und A11y/Form-Mechanik erhalten bleiben. */
.sueco-designer-font-card__input {
	position: absolute;
	width: 18px;
	height: 18px;
	margin: 0;
	left: 16px;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0;
	cursor: pointer;
}

.sueco-designer-font-card__radio {
	width: 18px;
	height: 18px;
	border: 2px solid var(--sueco-border, #e7e5e4);
	border-radius: 50%;
	background: var(--sueco-white, #ffffff);
	position: relative;
	transition: border-color 150ms ease-out;
}

.sueco-designer-font-card__radio::after {
	content: '';
	position: absolute;
	inset: 3px;
	border-radius: 50%;
	background: var(--sueco-primary, #8b5e3c);
	opacity: 0;
	transform: scale(0.6);
	transition: opacity 120ms ease-out, transform 120ms ease-out;
}

.sueco-designer-font-card__col {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.sueco-designer-font-card__eyebrow {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-font-card__sample {
	font-size: 22px;
	line-height: 1.2;
	color: var(--sueco-text-primary, #2d2926);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* „gewählt"-Pill — nur sichtbar bei :checked. */
.sueco-designer-font-card__badge {
	display: none;
	align-items: center;
	gap: 4px;
	padding: 4px 10px;
	border-radius: 999px;
	background: var(--sueco-primary, #8b5e3c);
	color: var(--sueco-white, #ffffff);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	white-space: nowrap;
}

.sueco-designer-font-card__badge svg {
	width: 12px;
	height: 12px;
}

/* Etappe-3.1-Smoke-Finding F-E-10: Selected-State trug zusätzlich zur
 * Border + Radio-Filling + „GEWÄHLT"-Badge auch noch einen Cream-BG —
 * insgesamt zu viel beige auf einer Cream-Modal-Fläche. Border + Badge
 * tragen die Signalwirkung allein, BG bleibt weiß. */
.sueco-designer-font-card:has(input:checked) {
	border-color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-font-card:has(input:checked) .sueco-designer-font-card__radio {
	border-color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-font-card:has(input:checked) .sueco-designer-font-card__radio::after {
	opacity: 1;
	transform: scale(1);
}

.sueco-designer-font-card:has(input:checked) .sueco-designer-font-card__badge {
	display: inline-flex;
}

/* 4a.1.2 — focus-within nur noch via Border-Color-Wechsel (keine
 * zusätzliche Box-Shadow-Outline mehr, da die Border bereits 2 px ist
 * und sonst doppelt aussieht). */
.sueco-designer-font-card:focus-within {
	border-color: var(--sueco-primary, #8b5e3c);
}

/* -----------------------------------------------------------------
   Review-Card (Spur 4 — Snapshot + Eyebrow + Edit + Meta + Summary).
   ----------------------------------------------------------------- */

.sueco-designer-review-card {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 18px;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
	background: var(--sueco-white, #ffffff);
}

.sueco-designer-review-card__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
}

.sueco-designer-review-card__eyebrow {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-review-card__edit {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: transparent;
	border: none;
	padding: 4px 8px;
	margin: -4px -8px;
	color: var(--sueco-primary, #8b5e3c);
	font: inherit;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	border-radius: 6px;
}

.sueco-designer-review-card__edit:hover,
.sueco-designer-review-card__edit:focus-visible {
	background: var(--sueco-bg-cream, #fbf6ec);
	outline: none;
}

.sueco-designer-review-card__edit svg {
	width: 14px;
	height: 14px;
}

.sueco-designer-review-card__snapshot {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 12px;
	background: var(--sueco-bg-cream, #fbf6ec);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 10px;
	min-height: 140px;
}

.sueco-designer-review-card__snapshot-img {
	max-width: 100%;
	max-height: 240px;
	height: auto;
	display: block;
}

.sueco-designer-review-card__snapshot-fallback {
	font-size: 12px;
	color: var(--sueco-text-secondary, #57534e);
	font-style: italic;
}

.sueco-designer-review-card__meta {
	display: grid;
	grid-template-columns: max-content 1fr;
	column-gap: 16px;
	row-gap: 6px;
	margin: 0;
	font-size: 14px;
}

.sueco-designer-review-card__meta dt {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
	align-self: start;
	padding-top: 2px;
}

.sueco-designer-review-card__meta dd {
	margin: 0;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-review-card__line {
	line-height: 1.4;
}

.sueco-designer-review-card__line--empty {
	color: var(--sueco-text-secondary, #57534e);
	font-style: italic;
}

.sueco-designer-review-card__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--sueco-border, #e7e5e4);
	font-size: 13px;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-review-card__summary-label strong {
	color: var(--sueco-text-primary, #2d2926);
	font-weight: 600;
}

/* -----------------------------------------------------------------
   Badge (für Summary-Row im Review, Spur 4).
   ----------------------------------------------------------------- */

.sueco-designer-badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	white-space: nowrap;
}

.sueco-designer-badge--success {
	background: #e8f1ea;
	color: #2f6a40;
}

.sueco-designer-stage {
	width: 100%;
}

/* -----------------------------------------------------------------
   Spur 6 — Loading / Save / Error.
   DOM-Hooks aus Block D (`index.js`):
   - `<dialog>.dataset.saving`     ('true' / 'false')
   - `<dialog>.dataset.saveError`  (Code-String, gesetzt nur bei Fehler)
   - Trigger-`<button>.dataset.hydrating`        ('true' während Load)
   - Trigger-`<button>.dataset.hydrationError`   (Code, persistent)
   ----------------------------------------------------------------- */

/* Save-Indikator als unauffälliger Inline-Hint in der Topbar. Kein
 * Spinner-Asset; Text reicht für die Phase. Wird via ::after an die
 * Topbar gehängt, damit kein DOM-Patch im Wizard nötig ist. */
.sueco-designer-modal[data-saving="true"] .sueco-designer-modal__bar::after {
	content: 'Wird gespeichert …';
	font-size: 12px;
	color: var(--sueco-text-secondary, #57534e);
	opacity: 0.85;
	margin-left: 8px;
	white-space: nowrap;
}

/* Save-Error-Banner — taucht zwischen Topbar und Progress auf, sobald
 * der Adapter `onSaveError` feuert. Wird beim nächsten erfolgreichen
 * Save automatisch gelöscht (siehe `index.js` onSavingChange). */
.sueco-designer-modal[data-save-error] .sueco-designer-modal__progress::before {
	content: 'Speichern fehlgeschlagen — bitte erneut versuchen.';
	display: block;
	padding: 8px 12px;
	margin: -10px -16px 10px;
	background: var(--sueco-error-bg, #fadddc);
	color: var(--sueco-error-fg, #993a32);
	font-size: 12px;
	font-weight: 500;
	border-bottom: 1px solid var(--sueco-border, #e7e5e4);
}

/* G4-α.1 Save-Error-Banner für das Single-Page-Layout (es hat keine
 * Progress-Bar mehr — der Hinweis hängt an der Topbar). */
.sueco-designer-modal--editor[data-save-error] .sueco-designer-modal__bar--top::after {
	content: 'Speichern fehlgeschlagen — bitte erneut versuchen.';
	order: 5;
	flex-basis: 100%;
	margin-top: 6px;
	padding: 6px 10px;
	border-radius: 6px;
	background: var(--sueco-error-bg, #fadddc);
	color: var(--sueco-error-fg, #993a32);
	font-size: 12px;
	font-weight: 500;
}

/* =================================================================
   Single-Page-Editor (Block G Etappe G4).
   Der `<dialog>`-Container (.sueco-designer-modal) bleibt — 100vh,
   Backdrop, [open]→flex-column. Hier kommt nur der Single-Page-Inhalt:
   scrollbarer Content mit Sticky-Live-Vorschau + Sticky-Bottombar.

   Sticky-Mechanik (Mockup-Finding F-14): der dialog ist der
   flex-column-Frame, `__content` ist der EINZIGE Scroll-Container
   (flex:1 + min-height:0 + overflow-y:auto), Topbar/Bottombar sind
   flex-Items oben/unten. Die Live-Vorschau klebt mit position:sticky
   innerhalb des Content-Scrollbereichs.
   ================================================================= */

.sueco-designer-editor__content {
	flex: 1;
	min-height: 0;
	overflow-y: auto;
	/* Smoke 2026-05-29: `__content` ist der einzige Scroll-Container. Ohne
	   contain sickert das Wheel-Event am Scroll-Ende (oder über nicht-
	   scrollbaren Stellen) auf die Seite hinter dem <dialog> durch — die
	   Hintergrund-Seite scrollt mit. contain kappt das Scroll-Chaining;
	   der Body-Scroll-Lock in Editor.open() ist die zweite Sicherung. */
	overscroll-behavior: contain;
	display: flex;
	flex-direction: column;
	gap: 14px;
	/* padding-top als Variable: die sticky `__preview` spiegelt sie als
	   negativen `top`, damit sie geklebt bündig unter den Header rückt und
	   kein durchscrollender Spalt über ihr offen bleibt (Smoke 2026-05-29). */
	--sueco-editor-pad-top: 14px;
	padding: var(--sueco-editor-pad-top) 16px 18px;
}

.sueco-designer-editor__lead {
	margin: 0;
	font-size: 13px;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-editor__lead:empty {
	display: none;
}

.sueco-designer-editor__title {
	margin: 2px 0 0;
	font-family: var(--sueco-font-heading, "Playfair Display", Georgia, serif);
	font-size: 19px;
	font-weight: 600;
	line-height: 1.2;
	color: var(--sueco-text-primary, #2d2926);
}

/* Live-Vorschau — klebt oben im Content-Scrollbereich. */
.sueco-designer-editor__preview {
	position: sticky;
	/* negativer top = −padding-top des Scroll-Containers: zieht die geklebte
	   Vorschau bündig unter den Header. Mit top:0 bliebe der padding-Streifen
	   als durchscrollender Spalt darüber sichtbar (Smoke 2026-05-29). */
	top: calc(-1 * var(--sueco-editor-pad-top, 14px));
	z-index: 5;
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 12px;
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
	box-shadow: 0 6px 12px -8px rgba(58, 37, 23, 0.18);
}

.sueco-designer-editor__stage {
	width: 100%;
	/* G4-ζ-2: Mobile schmaler (war 320px) → kleinere Vorschau, mehr Platz
	   fürs Bedienen unter dem sticky Canvas. Desktop-MQ hebt das wieder an. */
	max-width: 280px;
	margin: 0 auto;
	/* G4-ζ: kein min-height mehr. min-height:180px hat bei breit-flachen
	   Produkten (Anhänger) die aspect-ratio überstimmt → der Konva-Canvas
	   (breiten-getrieben, Höhe = Breite × aspect) füllte nur den oberen Teil,
	   darunter blieb ein weißes Letterbox-Band (Julio-Smoke 2026-05-30). Die
	   aspect-ratio (per JS aus den Produktmaßen, Editor.ensureStage) treibt die
	   Höhe jetzt allein; der 4/3-Default greift nur im Sekundenbruchteil vor
	   dem JS-Set. */
	aspect-ratio: 4 / 3;
}

/* G4-ζ: nicht-sticky Kopfzone über dem sticky Canvas (Bedienhilfe, Caption,
   Zoom-Button). Scrollt weg, sticky bleibt allein der Canvas darunter. */
.sueco-designer-editor__previewhead {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

/* Caption (Auswahl-Hinweis + Feldmaße) — war zuvor __preview-footer unter
   dem Canvas, sitzt jetzt in der Kopfzone. */
.sueco-designer-editor__caption {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	font-size: 11px;
	color: var(--sueco-text-secondary, #57534e);
}

/* Bedienhilfe — natives <details>, dezente Karte, Default eingeklappt. */
.sueco-designer-editor__help {
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 10px;
}

.sueco-designer-editor__help-summary {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	font-size: 13px;
	font-weight: 600;
	color: var(--sueco-text-primary, #2d2926);
	cursor: pointer;
	/* Default-Dreieck weg (Firefox/Standard); WebKit unten separat. */
	list-style: none;
}

.sueco-designer-editor__help-summary::-webkit-details-marker {
	display: none;
}

/* Eigener Chevron: › eingeklappt, ⌄ offen. */
.sueco-designer-editor__help-summary::before {
	content: "";
	flex: 0 0 auto;
	width: 7px;
	height: 7px;
	border-right: 2px solid var(--sueco-primary, #8b5e3c);
	border-bottom: 2px solid var(--sueco-primary, #8b5e3c);
	transform: rotate(-45deg);
	transition: transform 0.15s ease;
}

.sueco-designer-editor__help[open] .sueco-designer-editor__help-summary::before {
	transform: rotate(45deg);
}

.sueco-designer-editor__help-list {
	margin: 0;
	padding: 0 14px 12px 32px;
	font-size: 12px;
	line-height: 1.45;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-editor__help-list li + li {
	margin-top: 4px;
}

.sueco-designer-editor__scale {
	letter-spacing: 0.04em;
	text-align: right;
}

/* Zoom-Toggle (G4-γ S-2): schaltet Gesamtansicht ⟷ Gravurfeld-Closeup.
   Dezenter Pill-Button, zentriert unter der Stage; nur sichtbar, wenn ein
   Closeup sinnvoll ist (kleines Feld — setupCloseup entscheidet). */
.sueco-designer-editor__zoom-toggle {
	align-self: center;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	font: inherit;
	font-size: 12px;
	line-height: 1;
	color: var(--sueco-primary, #8b5e3c);
	background: transparent;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 999px;
	cursor: pointer;
}

.sueco-designer-editor__zoom-toggle:hover {
	background: var(--sueco-bg-cream, #fbf6ec);
}

/* G4-θ.2 (Julio 2026-05-31): Hervorgehobener Zustand — gefüllter Primary-
   Look statt dezenter Pill. Nur aktiv, solange der Zoom-Toggle noch nie
   benutzt wurde UND er „Gravurfeld heranzoomen" anbietet (updateZoomToggle);
   „Gesamtansicht" bleibt die dezente Basis-Pill. Der Button ist die
   wichtigste Aktion zum Bedienen kleiner Gravurfelder und soll sofort ins
   Auge fallen. Nur Farb-/Gewicht-/Schatten-Wechsel, keine Box-Änderung →
   kein Layout-Shift, wenn die Hervorhebung nach dem ersten Klick wegfällt. */
.sueco-designer-editor__zoom-toggle--highlight {
	color: var(--sueco-white, #ffffff);
	background: var(--sueco-primary, #8b5e3c);
	border-color: var(--sueco-primary, #8b5e3c);
	font-weight: 600;
	box-shadow: 0 2px 8px -2px rgba(139, 94, 60, 0.45);
}

/* Hover muss die Basis-:hover (cream-Background) überschreiben — gleiche
   Spezifität, daher steht diese Regel bewusst danach. */
.sueco-designer-editor__zoom-toggle--highlight:hover {
	background: var(--sueco-primary, #8b5e3c);
	filter: brightness(0.94);
}

/* [hidden] braucht explizit display:none, sonst gewinnt display:inline-flex. */
.sueco-designer-editor__zoom-toggle[hidden] {
	display: none;
}

.sueco-designer-editor__zoom-toggle-icon {
	display: inline-flex;
	width: 16px;
	height: 16px;
}

.sueco-designer-editor__zoom-toggle-icon svg {
	width: 16px;
	height: 16px;
}

/* Funktionale Panel-Slots — in α.1 leer; befüllt in α.2 (Layers/Add),
   α.4 (Quick-Transform), β (Eigenschaften). Leer = kein Layout-Platz. */
.sueco-designer-editor__quicktransform:empty,
.sueco-designer-editor__layers:empty,
.sueco-designer-editor__props:empty {
	display: none;
}

/* Sticky-Bottombar — klebt unten, Primary-CTA + (später) Service-Switch.
   G4-θ (Julio 2026-05-31): mehr Luft + zentrierter Inhalt — der CTA wirkt
   so als bewusst gesetzte Aktionsleiste statt als angeschnittener Streifen. */
.sueco-designer-editor__bottombar {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 16px 16px calc(20px + env(safe-area-inset-bottom));
	background: var(--sueco-bg-cream, #fbf6ec);
	border-top: 1px solid var(--sueco-border, #e7e5e4);
	position: sticky;
	bottom: 0;
	z-index: 20;
}

/* CTA — G4-θ: zentriert (war justify-content:space-between für einen Preis
   rechts, der nie kam → Label klebte links). Vollbreit auf Mobile für ein
   großes Touch-Target; Desktop begrenzt die Breite (s. ≥768px-MQ). */
.sueco-designer-editor__cta {
	justify-content: center;
	width: 100%;
}

/* Layout-Spalten (G4-β.4). Mobile: vertikaler Stack mit denselben 14px-
   Gaps wie zuvor der flache Content-Stack — die Sticky-Preview-Mechanik
   (F-14) bleibt unverändert, weil `.__content` weiter der Scroll-Container
   ist und die Preview per sticky:top:0 durch den Wrapper hindurch klebt. */
.sueco-designer-editor__col {
	/* Mobile: Wrapper layout-transparent (display:contents) — preview,
	   quicktransform / props, layers reihen sich direkt in den
	   __content-Scroll-Stack ein (Zustand vor G4-β.4). Nur so ist die
	   sticky `__preview` wieder ein direktes Flow-Kind des Scroll-Containers
	   und klebt über die VOLLE Content-Höhe — statt nur bis zur Unterkante
	   des Wrappers (sticky-Containing-Block-Falle, Smoke 2026-05-29: Vorschau
	   fiel beim Weiterscrollen raus). Desktop stellt display:flex in der
	   ≥768px-MQ wieder her, damit die Grid-Spalten Boxen behalten. */
	display: contents;
}

/* Desktop (≥768 px): Der dialog wird über die bestehende
   .sueco-designer-modal-Media-Query zum zentrierten Panel. Two-Column-
   Layout (G4-β.4, Code-Brief 2): Sticky-Vorschau-Spalte links, Bedien-
   Spalte rechts; lead/title/trust spannen über beide. Konva unberührt. */
@media (min-width: 768px) {
	.sueco-designer-editor__content {
		display: grid;
		/* G4-θ: rechte Bedien-Spalte etwas breiter — sie trägt jetzt Inhalt,
		   Schrift, das 4er-Button-Grid und die Ebenen-Liste; die Vorschau
		   links kommt mit weniger Breite aus. */
		grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
		column-gap: 24px;
		row-gap: 14px;
		align-items: start;
	}

	/* Desktop: die Spalten-Wrapper bekommen ihre Box zurück (Mobile-Basis
	   ist display:contents) — sonst zählen sie nicht als Grid-Items und das
	   Two-Column-Layout kollabiert. */
	.sueco-designer-editor__col--preview,
	.sueco-designer-editor__col--controls {
		display: flex;
		flex-direction: column;
		gap: 14px;
		min-width: 0;
	}

	.sueco-designer-editor__lead,
	.sueco-designer-editor__title,
	.sueco-designer-editor__trust {
		grid-column: 1 / -1;
	}

	.sueco-designer-editor__col--preview {
		grid-column: 1;
		position: sticky;
		top: 0;
		align-self: start;
	}

	.sueco-designer-editor__col--controls {
		grid-column: 2;
	}

	/* Die ganze Vorschau-Spalte klebt jetzt — die innere Preview braucht
	   kein eigenes Sticky mehr (sonst doppelt-sticky). */
	.sueco-designer-editor__preview {
		position: static;
		box-shadow: none;
	}

	.sueco-designer-editor__stage {
		max-width: 420px;
	}

	/* G4-θ: Die Vorschau-Spalte enthält jetzt NUR noch Kopfzone + Vorschau-
	   Card — alle Bedien-Elemente der aktiven Ebene (Inhalt, Schrift,
	   Position/Größe) sowie die Ebenen-Liste leben rechts in --controls.
	   Damit ist die linke Spalte schlank genug, um vollständig zu kleben,
	   und die Quick-Transform-Bar kollidiert nicht mehr mit der CTA-Leiste. */

	/* CTA auf Desktop nicht über die volle Spaltenbreite, sondern als
	   bewusst gesetzter Button mittig in der Leiste (Julio-Wahl „zentriert
	   + Card"). */
	.sueco-designer-editor__cta {
		max-width: 460px;
	}
}

/* -----------------------------------------------------------------
   Ebenen-Panel (Block G Etappe G4-α.2).
   ----------------------------------------------------------------- */

.sueco-designer-layers {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sueco-designer-layers__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin-bottom: 2px;
}

/* G4-δ-4: Header ist ein Toggle-Button (klappt die Liste auf/zu); das
   kompakte (+) bleibt daneben immer erreichbar. */
.sueco-designer-layers__toggle {
	display: flex;
	align-items: center;
	gap: 6px;
	flex: 1 1 auto;
	min-width: 0;
	padding: 4px 0;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	color: inherit;
}

.sueco-designer-layers__caret {
	display: inline-flex;
	color: var(--sueco-text-secondary, #57534e);
	transform: rotate(-90deg);
	transition: transform 0.15s ease;
}

.sueco-designer-layers[data-expanded="true"] .sueco-designer-layers__caret {
	transform: rotate(0deg);
}

.sueco-designer-layers__caret svg {
	width: 16px;
	height: 16px;
}

.sueco-designer-layers__title {
	margin: 0;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-layers__count {
	font-size: 11px;
	color: var(--sueco-text-secondary, #57534e);
}

/* G4-ε-5: deutlich hervorgehoben — gefüllter Primary-Button statt dezenter
   Outline, damit das Hinzufügen klar als primäre Aktion gelesen wird. */
.sueco-designer-layers__add {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	flex: 0 0 auto;
	padding: 7px 13px;
	font-size: 13px;
	font-weight: 600;
	color: var(--sueco-white, #ffffff);
	background: var(--sueco-primary, #8b5e3c);
	border: 1px solid var(--sueco-primary, #8b5e3c);
	border-radius: 8px;
	cursor: pointer;
	box-shadow: 0 1px 2px rgba(45, 41, 38, 0.12);
}

.sueco-designer-layers__add:hover,
.sueco-designer-layers__add:focus-visible {
	background: var(--sueco-primary-hover, #704930);
	border-color: var(--sueco-primary-hover, #704930);
	outline: none;
}

.sueco-designer-layers__add-icon {
	display: inline-flex;
}

.sueco-designer-layers__add-icon svg {
	width: 14px;
	height: 14px;
}

/* Body (Karten-Liste): nur sichtbar, wenn ausgeklappt. */
.sueco-designer-layers__body {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sueco-designer-layers[data-expanded="false"] .sueco-designer-layers__body {
	display: none;
}

.sueco-designer-layer {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 10px;
	cursor: pointer;
}

/* Selected-State (F-03): Primary-Border + Inset-Shadow als doppelter
   Rahmen, damit die aktive Ebene sich klar vom Cream-Frame abhebt. */
.sueco-designer-layer--active {
	border-color: var(--sueco-primary, #8b5e3c);
	box-shadow: 0 0 0 1px var(--sueco-primary, #8b5e3c) inset;
}

.sueco-designer-layer__icon {
	flex: 0 0 auto;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--sueco-bg-cream, #fbf6ec);
	border: 1px solid var(--sueco-border, #e7e5e4);
	color: var(--sueco-primary, #8b5e3c);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.sueco-designer-layer__icon svg {
	width: 18px;
	height: 18px;
}

.sueco-designer-layer__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	flex: 1;
	min-width: 0;
}

.sueco-designer-layer__label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-layer__value {
	font-size: 14px;
	font-weight: 500;
	color: var(--sueco-text-primary, #2d2926);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sueco-designer-layer__meta {
	font-size: 11px;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-layer__delete {
	flex: 0 0 auto;
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: var(--sueco-text-secondary, #57534e);
	cursor: pointer;
}

.sueco-designer-layer__delete svg {
	width: 16px;
	height: 16px;
}

.sueco-designer-layer__delete:hover,
.sueco-designer-layer__delete:focus-visible {
	background: var(--sueco-error-bg, #fadddc);
	color: var(--sueco-error-fg, #993a32);
	outline: none;
}

/* Empty-State (F-11) — Hero-Card statt Ebenen-Liste. */
.sueco-designer-empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 8px;
	padding: 22px 20px 24px;
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
}

.sueco-designer-empty__icon {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background: var(--sueco-bg-cream, #fbf6ec);
	color: var(--sueco-primary, #8b5e3c);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.sueco-designer-empty__icon svg {
	width: 24px;
	height: 24px;
}

.sueco-designer-empty__title {
	margin: 2px 0 0;
	font-family: var(--sueco-font-heading, "Playfair Display", Georgia, serif);
	font-size: 17px;
	font-weight: 600;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-empty__text {
	margin: 0;
	max-width: 30em;
	font-size: 13px;
	line-height: 1.5;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-empty__cta {
	flex: 0 0 auto;
	margin-top: 6px;
	width: auto;
	padding-inline: 22px;
}

/* -----------------------------------------------------------------
   Add-Sheet (Bottom-Sheet im Editor-dialog, Block G G4-α.2).
   ----------------------------------------------------------------- */

.sueco-designer-sheet-overlay {
	position: absolute;
	inset: 0;
	z-index: 40;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background: rgba(28, 28, 28, 0.45);
}

.sueco-designer-sheet {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 20px 18px calc(20px + env(safe-area-inset-bottom));
	background: var(--sueco-bg-cream, #fbf6ec);
	border-radius: 16px 16px 0 0;
	box-shadow: 0 -8px 24px -12px rgba(28, 28, 28, 0.4);
}

.sueco-designer-sheet__close {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: transparent;
	color: var(--sueco-text-secondary, #57534e);
	cursor: pointer;
}

.sueco-designer-sheet__close:hover {
	background: var(--sueco-bg-gray, #f4f4f5);
}

.sueco-designer-sheet__close svg {
	width: 18px;
	height: 18px;
}

.sueco-designer-sheet__title {
	margin: 0 32px 0 0;
	font-family: var(--sueco-font-heading, "Playfair Display", Georgia, serif);
	font-size: 18px;
	font-weight: 600;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-sheet__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.sueco-designer-sheet__soon {
	display: flex;
	gap: 10px;
	margin-top: 4px;
}

.sueco-designer-sheet__soon-item {
	flex: 1;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 12px;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 10px;
	background: var(--sueco-bg-gray, #f4f4f5);
	color: var(--sueco-text-secondary, #57534e);
	font-size: 13px;
	font-weight: 600;
	opacity: 0.7;
}

.sueco-designer-sheet__soon-icon {
	display: inline-flex;
}

.sueco-designer-sheet__soon-icon svg {
	width: 18px;
	height: 18px;
}

.sueco-designer-sheet__cancel {
	align-self: center;
	margin-top: 2px;
}

.sueco-designer-badge--soon {
	margin-left: auto;
	padding: 2px 8px;
	border-radius: 999px;
	background: var(--sueco-border, #e7e5e4);
	color: var(--sueco-text-secondary, #57534e);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* -----------------------------------------------------------------
   Quick-Transform-Bar (Block G Etappe G4-α.4).
   Direkt unter der Sticky-Live-Vorschau, Daumen-Zone (F-02).
   ----------------------------------------------------------------- */

.sueco-designer-quicktransform {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 10px 12px 12px;
	background: var(--sueco-white, #ffffff);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
}

.sueco-designer-quicktransform__head {
	display: flex;
	align-items: baseline;
	gap: 8px;
}

.sueco-designer-quicktransform__label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-quicktransform__value {
	font-size: 13px;
	font-weight: 500;
	color: var(--sueco-text-primary, #2d2926);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sueco-designer-quicktransform__row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 6px;
}

.sueco-designer-move-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 8px;
	background: var(--sueco-bg-cream, #fbf6ec);
	color: var(--sueco-primary, #8b5e3c);
	cursor: pointer;
}

.sueco-designer-move-btn:hover,
.sueco-designer-move-btn:focus-visible {
	border-color: var(--sueco-primary, #8b5e3c);
	outline: none;
}

.sueco-designer-move-btn svg {
	width: 20px;
	height: 20px;
}

.sueco-designer-action-btn {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	min-height: 56px;
	padding: 6px 4px;
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 8px;
	background: var(--sueco-white, #ffffff);
	color: var(--sueco-primary, #8b5e3c);
	font: inherit;
	cursor: pointer;
}

.sueco-designer-action-btn:hover:not(:disabled),
.sueco-designer-action-btn:focus-visible {
	border-color: var(--sueco-primary, #8b5e3c);
	outline: none;
}

/* G4-ε-1: am Größen-Limit ausgegraut — macht den Mindest-/Höchstwert
   sichtbar (sonst tut der Button nichts und es fühlt sich grenzenlos an). */
.sueco-designer-action-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.sueco-designer-action-btn svg {
	width: 22px;
	height: 22px;
}

.sueco-designer-action-btn__label {
	font-size: 11px;
	font-weight: 600;
	color: var(--sueco-text-secondary, #57534e);
	white-space: nowrap;
}

/* -----------------------------------------------------------------
   Eigenschaften-Panel (Block G Etappe G4-β.1).
   Akkordeon der aktiven Ebene: Inhalt + Schrift (Mockup 03-editor §props).
   `.sueco-designer-field__input` wird wiederverwendet (Z. 443) — hier nur
   die Panel-/Akkordeon-/Chip-/Counter-Styles.
   ----------------------------------------------------------------- */

.sueco-designer-props {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.sueco-designer-props-section {
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 10px;
	background: var(--sueco-white, #ffffff);
	overflow: hidden;
}

.sueco-designer-props-section__head {
	display: grid;
	grid-template-columns: 20px auto 1fr 16px;
	align-items: center;
	column-gap: 10px;
	width: 100%;
	padding: 12px 14px;
	border: 0;
	background: transparent;
	font: inherit;
	text-align: left;
	cursor: pointer;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-props-section__icon {
	display: inline-flex;
	color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-props-section__icon svg {
	width: 18px;
	height: 18px;
}

.sueco-designer-props-section__title {
	font-size: 14px;
	font-weight: 600;
}

.sueco-designer-props-section__hint {
	font-size: 11px;
	color: var(--sueco-text-secondary, #57534e);
	text-align: right;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sueco-designer-props-section__caret {
	display: inline-flex;
	color: var(--sueco-text-secondary, #57534e);
	transition: transform 150ms ease-out;
}

.sueco-designer-props-section__caret svg {
	width: 16px;
	height: 16px;
}

.sueco-designer-props-section[data-open="false"] .sueco-designer-props-section__caret {
	transform: rotate(-90deg);
}

.sueco-designer-props-section__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 0 14px 14px;
}

.sueco-designer-props-section[data-open="false"] .sueco-designer-props-section__body {
	display: none;
}

.sueco-designer-props-section__caption {
	margin: 0;
	font-size: 11px;
	color: var(--sueco-text-secondary, #57534e);
}

/* „Text zu lang"-Hinweis (G4-γ S-1) — ersetzt den früheren Zeichen-Counter.
   Einzige textuelle Warnung; Sichtbarkeit toggelt der Editor aus
   overflowsField (synchron zur roten Stage-Outline). */
.sueco-designer-field__overflow-hint {
	margin: 0;
	font-size: 12px;
	line-height: 1.3;
	color: var(--sueco-error-fg, #993a32);
}

.sueco-designer-field__overflow-hint[hidden] {
	display: none;
}

/* Font-Chips: 5-Spalten-Grid (F-09), Aa-Sample + Kurzname. */
.sueco-designer-font-chips {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 6px;
}

.sueco-designer-font-chip {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 3px;
	padding: 8px 2px;
	border: 2px solid var(--sueco-border, #e7e5e4);
	border-radius: 8px;
	background: var(--sueco-white, #ffffff);
	cursor: pointer;
	transition: border-color 150ms ease-out;
}

.sueco-designer-font-chip:hover,
.sueco-designer-font-chip:focus-visible {
	border-color: var(--sueco-primary, #8b5e3c);
	outline: none;
}

.sueco-designer-font-chip__sample {
	font-size: 22px;
	line-height: 1;
	color: var(--sueco-text-primary, #2d2926);
}

.sueco-designer-font-chip__name {
	max-width: 100%;
	font-size: 10px;
	color: var(--sueco-text-secondary, #57534e);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sueco-designer-font-chip--selected {
	border-color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-font-chip--selected .sueco-designer-font-chip__name {
	color: var(--sueco-primary, #8b5e3c);
	font-weight: 600;
}

/* -----------------------------------------------------------------
   Limits + Guards (Block G Etappe G4-β.2).
   ----------------------------------------------------------------- */

/* Ebenen-Limit-Hinweis (ersetzt den (+)-Button bei max. Ebenen). */
.sueco-designer-layers__limit {
	margin: 2px 0 0;
	padding: 10px 12px;
	font-size: 12px;
	text-align: center;
	color: var(--sueco-text-secondary, #57534e);
	background: var(--sueco-bg-cream, #fbf6ec);
	border: 1px dashed var(--sueco-border, #e7e5e4);
	border-radius: 8px;
}

/* Leer-Order-Hinweis über dem CTA (Leer-Order-Guard #7). Der CTA selbst
   ist via .sueco-designer-button--primary:disabled gegreyed. */
.sueco-designer-editor__cta-hint {
	margin: 0;
	font-size: 12px;
	text-align: center;
	color: var(--sueco-text-secondary, #57534e);
}

.sueco-designer-editor__cta-hint[hidden] {
	display: none;
}

/* -----------------------------------------------------------------
   Trust-Marker-Row (Block G Etappe G4-β.4, F-13/F-16).
   Drei Service-Versprechen zwischen Bedienung und Sticky-CTA.
   ----------------------------------------------------------------- */

.sueco-designer-editor__trust {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 14px;
	background: var(--sueco-bg-cream, #fbf6ec);
	border: 1px solid var(--sueco-border, #e7e5e4);
	border-radius: 12px;
}

.sueco-designer-trust {
	display: flex;
	align-items: flex-start;
	gap: 10px;
}

.sueco-designer-trust__icon {
	flex: 0 0 auto;
	display: inline-flex;
	color: var(--sueco-primary, #8b5e3c);
}

.sueco-designer-trust__icon svg {
	width: 20px;
	height: 20px;
}

.sueco-designer-trust__text {
	font-size: 12px;
	line-height: 1.4;
	color: var(--sueco-text-secondary, #57534e);
}
