/* ================================================
   FormForge — form.css (frontend)
   ================================================
   Variables CSS : valeurs par défaut. Surchargées par <style id="formforge-appearance-vars">
   injecté dans <head> par FormForge_Appearance::render_inline_style().
   ================================================ */

:root {
	--ff-color-primary:      #2271b1;
	--ff-color-primary-dark: #135e96;
	--ff-color-text:         #1d2327;
	--ff-color-muted:        #666666;
	--ff-color-bg:           #ffffff;
	--ff-color-border:       #d0d5dd;
	--ff-font-family:        -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--ff-font-size:          14px;
	--ff-radius:             4px;
	--ff-form-max-width:     720px;
	--ff-input-padding-y:    8px;
	--ff-input-padding-x:    10px;
	--ff-button-padding-y:   10px;
	--ff-button-padding-x:   22px;
}

.formforge-form {
	max-width: var(--ff-form-max-width);
	margin: 0 auto;
	background: var(--ff-color-bg);
	color: var(--ff-color-text);
	padding: 24px 28px;
	border: 1px solid var(--ff-color-border);
	border-radius: calc(var(--ff-radius) * 2);
	box-shadow: 0 1px 3px rgba(0,0,0,.04);
	font-family: var(--ff-font-family);
	font-size: var(--ff-font-size);
}

.formforge-form-title {
	margin: 0 0 6px;
	font-size: calc(var(--ff-font-size) + 8px);
	color: var(--ff-color-text);
}
.formforge-form-desc {
	margin: 0 0 18px;
	color: var(--ff-color-muted);
	font-size: var(--ff-font-size);
}

/* Progress bar (multi-pages) */
.formforge-progress {
	display: flex;
	gap: 8px;
	list-style: none;
	margin: 0 0 24px;
	padding: 0;
}
.formforge-progress-step {
	flex: 1;
	height: 4px;
	background: var(--ff-color-border);
	border-radius: 2px;
	position: relative;
}
.formforge-progress-step.is-current {
	background: var(--ff-color-primary);
}
.formforge-progress-step.is-done {
	background: var(--ff-color-primary);
	opacity: 0.5;
}
.formforge-progress-num {
	position: absolute;
	top: -22px;
	left: 50%;
	transform: translateX( -50% );
	font-size: 11px;
	color: var(--ff-color-muted);
}

/* Pages */
.formforge-page {
	display: none;
}
.formforge-page.is-active {
	display: block;
}

/* Champs */
.formforge-field {
	margin-bottom: 18px;
}
.formforge-label {
	display: block;
	font-weight: 500;
	margin-bottom: 6px;
	font-size: var(--ff-font-size);
	color: var(--ff-color-text);
}
.formforge-required {
	color: #d63638;
	margin-left: 2px;
}
.formforge-field input[type="text"],
.formforge-field input[type="email"],
.formforge-field input[type="number"],
.formforge-field input[type="url"],
.formforge-field input[type="tel"],
.formforge-field input[type="password"],
.formforge-field textarea,
.formforge-field select {
	width: 100%;
	padding: var(--ff-input-padding-y) var(--ff-input-padding-x);
	border: 1px solid var(--ff-color-border);
	border-radius: var(--ff-radius);
	font-size: var(--ff-font-size);
	font-family: inherit;
	color: var(--ff-color-text);
	background: var(--ff-color-bg);
	box-sizing: border-box;
}
.formforge-field input:focus,
.formforge-field textarea:focus,
.formforge-field select:focus {
	outline: none;
	border-color: var(--ff-color-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--ff-color-primary) 15%, transparent);
}
.formforge-field textarea { resize: vertical; min-height: 80px; }
.formforge-field input[type="date"] {
	width: auto;
	min-width: 200px;
}

/* Radio + Checkbox groups */
.formforge-radio-group,
.formforge-checkbox-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.formforge-radio-choice,
.formforge-checkbox-choice {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 10px;
	border: 1px solid var(--ff-color-border);
	border-radius: var(--ff-radius);
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
	font-size: var(--ff-font-size);
	color: var(--ff-color-text);
}
.formforge-radio-choice:hover,
.formforge-checkbox-choice:hover {
	background: color-mix(in srgb, var(--ff-color-primary) 6%, var(--ff-color-bg));
	border-color: color-mix(in srgb, var(--ff-color-primary) 40%, var(--ff-color-border));
}
.formforge-radio-choice input,
.formforge-checkbox-choice input {
	width: auto;
	margin: 0;
	flex: 0 0 auto;
}

/* Bloc HTML libre */
.formforge-field-html {
	margin: 12px 0;
}
.formforge-field-html h1,
.formforge-field-html h2,
.formforge-field-html h3 { margin-top: 0; }

/* Champ masqué par logique conditionnelle */
.formforge-hidden-by-cond {
	display: none !important;
}

/* Range / curseur */
.formforge-field-range .formforge-range-wrap {
	display: flex;
	align-items: center;
	gap: 12px;
}
.formforge-field-range input[type="range"] {
	flex: 1;
	width: auto;
	padding: 0;
	background: transparent;
	border: none;
	box-shadow: none;
}
.formforge-range-output {
	min-width: 40px;
	text-align: right;
	font-variant-numeric: tabular-nums;
	font-weight: 500;
	color: #2271b1;
	background: #f0f6fc;
	padding: 4px 8px;
	border-radius: 3px;
}

/* Rating étoiles */
.formforge-field-rating .formforge-rating {
	display: inline-flex;
	flex-direction: row-reverse;
	gap: 2px;
	font-size: 28px;
	line-height: 1;
}
.formforge-field-rating .formforge-rating input[type="radio"] {
	display: none;
}
.formforge-field-rating .formforge-rating label {
	cursor: pointer;
	color: #d1d5db;
	transition: color 0.1s ease-in-out;
	margin: 0;
	font-weight: normal;
	user-select: none;
}
.formforge-field-rating .formforge-rating label:hover,
.formforge-field-rating .formforge-rating label:hover ~ label,
.formforge-field-rating .formforge-rating input[type="radio"]:checked ~ label {
	color: #f59e0b;
}

/* Tel / URL / Time / Datetime — héritent des styles input génériques. */

/* File upload */
.formforge-field-file input[type="file"] {
	width: 100%;
	padding: 8px;
	border: 1px dashed #d0d5dd;
	border-radius: 4px;
	background: #fafafa;
	font-family: inherit;
	font-size: 13px;
	cursor: pointer;
}
.formforge-field-file input[type="file"]:hover {
	border-color: #2271b1;
	background: #f0f6fc;
}
.formforge-field-file input[type="file"]::file-selector-button {
	padding: 6px 12px;
	margin-right: 12px;
	background: #2271b1;
	color: #fff;
	border: none;
	border-radius: 3px;
	cursor: pointer;
	font-size: 13px;
}
.formforge-field-file input[type="file"]::file-selector-button:hover {
	background: #135e96;
}
.formforge-file-hint {
	margin: 4px 0 0;
	font-size: 12px;
	color: #6b7280;
}
.formforge-file-current {
	margin: 6px 0 0;
	font-size: 13px;
	padding: 6px 10px;
	background: #f0f6fc;
	border-radius: 3px;
}
.formforge-file-current a {
	color: #2271b1;
	font-weight: 500;
}
.formforge-file-download {
	display: inline-block;
	color: #2271b1;
	text-decoration: none;
	font-weight: 500;
}
.formforge-file-download:hover {
	text-decoration: underline;
}

/* ================================================
   CHAMP SIGNATURE (canvas)
   ================================================ */
.formforge-field-signature .formforge-signature-wrap {
	display: inline-block;
	max-width: 100%;
	border: 2px dashed #d1d5db;
	border-radius: 8px;
	padding: 8px;
	background: #fff;
	position: relative;
}
.formforge-field-signature .formforge-signature-canvas {
	display: block;
	width: 100%;
	max-width: 600px;
	aspect-ratio: 600 / 180;
	background: #fafafa;
	cursor: crosshair;
	touch-action: none;
	border-radius: 4px;
	user-select: none;
}
.formforge-field-signature .formforge-signature-clear {
	display: inline-block;
	margin-top: 8px;
	padding: 6px 12px;
	background: #fff;
	border: 1px solid #d1d5db;
	border-radius: 4px;
	font-size: 13px;
	cursor: pointer;
	color: #4b5563;
}
.formforge-field-signature .formforge-signature-clear:hover {
	background: #f3f4f6;
	border-color: #9ca3af;
}
.formforge-field-signature .formforge-signature-current {
	margin: 6px 0 0;
	font-size: 13px;
	padding: 6px 10px;
	background: #f0f6fc;
	border-radius: 3px;
}

/* ================================================
   CHAMP REPEATER (Lignes répétables)
   ================================================ */

.formforge-repeater-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 8px;
}
.formforge-repeater-table th {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.4px;
	color: var(--ff-color-muted);
	font-weight: 500;
	padding: 6px 8px;
	border-bottom: 2px solid var(--ff-color-border);
	text-align: left;
}
.formforge-rep-col-qty,
.formforge-rep-col-price,
.formforge-rep-col-total { text-align: right !important; }
.formforge-rep-col-actions { width: 36px; }

.formforge-repeater-table td {
	padding: 4px 4px;
	vertical-align: middle;
}
.formforge-repeater-table input {
	width: 100%;
	padding: 6px 8px !important;
	font-size: 13px;
}
.formforge-rep-qty,
.formforge-rep-price { text-align: right; }

.formforge-rep-line-total {
	text-align: right;
	font-variant-numeric: tabular-nums;
	color: var(--ff-color-text);
	font-weight: 500;
	white-space: nowrap;
	padding-right: 10px !important;
}

.formforge-rep-remove {
	background: transparent;
	border: 1px solid var(--ff-color-border);
	color: #d63638;
	border-radius: var(--ff-radius);
	width: 28px;
	height: 28px;
	font-size: 14px;
	cursor: pointer;
	padding: 0;
	line-height: 1;
}
.formforge-rep-remove:hover {
	background: #fdf2f2;
	border-color: #d63638;
}

.formforge-rep-add {
	background: transparent;
	border: 1px dashed var(--ff-color-border);
	color: var(--ff-color-primary);
	padding: 8px 14px;
	border-radius: var(--ff-radius);
	cursor: pointer;
	font-size: 13px;
	font-family: inherit;
}
.formforge-rep-add:hover {
	background: color-mix(in srgb, var(--ff-color-primary) 8%, transparent);
	border-color: var(--ff-color-primary);
	border-style: solid;
}

.formforge-repeater-table tfoot td {
	border-top: 2px solid var(--ff-color-border);
	padding-top: 10px;
	font-weight: 700;
	font-size: 15px;
}
.formforge-rep-total-label { text-align: right; color: var(--ff-color-muted); }
.formforge-rep-total-amount {
	text-align: right;
	color: var(--ff-color-primary);
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

/* ================================================
   CALENDRIER HEBDOMADAIRE ([formforge_calendar])
   ================================================ */

.formforge-calendar {
	max-width: 960px;
	margin: 0 auto 24px;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.formforge-calendar-nav {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	background: #fff;
	border: 1px solid #e5e5e5;
	border-radius: 8px 8px 0 0;
	border-bottom: none;
}
.formforge-calendar-nav a {
	color: #2271b1;
	text-decoration: none;
	font-size: 13px;
	padding: 6px 10px;
	border-radius: 4px;
	transition: background 0.15s;
}
.formforge-calendar-nav a:hover { background: #f0f6fc; }
.formforge-cal-title {
	flex: 1;
	text-align: center;
	font-size: 15px;
	color: #1d2327;
}
.formforge-cal-spacer { flex: 0; }
.formforge-cal-today {
	font-weight: 500;
	background: #f0f6fc;
}

.formforge-calendar-scroll {
	overflow-x: auto;
	background: #fff;
	border: 1px solid #e5e5e5;
	border-radius: 0 0 8px 8px;
}

.formforge-calendar-grid {
	width: 100%;
	border-collapse: collapse;
	min-width: 600px;
}
.formforge-calendar-grid thead th {
	background: #f6f7f7;
	border-bottom: 2px solid #c3c4c7;
	padding: 10px 8px;
	text-align: center;
	font-size: 13px;
	color: #50575e;
	font-weight: 500;
}
.formforge-cal-dayname {
	display: block;
	text-transform: uppercase;
	font-size: 11px;
	letter-spacing: 0.5px;
	color: #888;
}
.formforge-cal-daynum {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: #1d2327;
	margin-top: 2px;
}
.formforge-cal-time-col {
	width: 70px;
	background: #fafafa;
	font-size: 12px;
	color: #555;
	text-align: right;
	padding-right: 10px;
	font-weight: 500;
	border-right: 1px solid #e5e5e5;
}
.formforge-calendar-grid tbody th.formforge-cal-time-col {
	font-variant-numeric: tabular-nums;
}

.formforge-cal-cell {
	padding: 0;
	border: 1px solid #e5e5e5;
	height: 38px;
	text-align: center;
	font-size: 12px;
	transition: background 0.15s, transform 0.05s;
	user-select: none;
}
.formforge-cal-cell.is-available {
	background: #d1e7dd;
	color: #0a3622;
	cursor: pointer;
}
.formforge-cal-cell.is-available:hover {
	background: #a3cfbb;
	transform: scale(0.98);
}
.formforge-cal-cell.is-available:focus-visible {
	outline: 3px solid #2271b1;
	outline-offset: -3px;
}
.formforge-cal-cell.is-taken {
	background: #f8d7da;
	color: #58151c;
	cursor: not-allowed;
	font-weight: 500;
}
.formforge-cal-cell.is-past {
	background: #fafafa;
	background-image: repeating-linear-gradient(
		135deg,
		transparent,
		transparent 6px,
		rgba( 0, 0, 0, 0.04 ) 6px,
		rgba( 0, 0, 0, 0.04 ) 7px
	);
	color: transparent;
	cursor: default;
}
.formforge-cal-cell.is-unavailable {
	background: #fff8e5;
	color: #8a6500;
	cursor: not-allowed;
	font-style: italic;
	font-size: 11px;
}
.formforge-cal-cell.is-unavailable.is-vacation {
	background: #ffe8d6;
	color: #9a4d00;
}
.formforge-cal-label {
	display: block;
	padding: 4px;
}

.formforge-cal-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
	margin: 12px 4px 0;
	font-size: 12px;
	color: #555;
}
.formforge-cal-legend-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.formforge-cal-legend-item::before {
	content: '';
	display: inline-block;
	width: 14px;
	height: 14px;
	border-radius: 3px;
}
.formforge-cal-legend-item.is-available::before { background: #d1e7dd; border: 1px solid #a3cfbb; }
.formforge-cal-legend-item.is-taken::before     { background: #f8d7da; border: 1px solid #f1aeb5; }
.formforge-cal-legend-item.is-unavailable::before { background: #fff8e5; border: 1px solid #f0c33c; }
.formforge-cal-legend-item.is-past::before {
	background: #fafafa;
	background-image: repeating-linear-gradient(
		135deg,
		transparent,
		transparent 3px,
		rgba( 0, 0, 0, 0.15 ) 3px,
		rgba( 0, 0, 0, 0.15 ) 4px
	);
	border: 1px solid #dcdcde;
}
.formforge-cal-legend-instructions {
	color: #777;
	font-style: italic;
	margin-left: auto;
}

/* Toast confirmation/erreur après clic sur un slot */
.formforge-cal-toast {
	position: fixed;
	bottom: 24px;
	right: 24px;
	background: #1d2327;
	color: #fff;
	padding: 12px 18px;
	border-radius: 6px;
	box-shadow: 0 8px 24px rgba( 0, 0, 0, 0.25 );
	font-size: 14px;
	max-width: 360px;
	opacity: 0;
	transform: translateY( 12px );
	transition: opacity 0.2s, transform 0.2s;
	z-index: 100050;
	pointer-events: none;
}
.formforge-cal-toast.is-visible {
	opacity: 1;
	transform: translateY( 0 );
}
.formforge-cal-toast.is-error {
	background: #d63638;
}

@media (max-width: 600px) {
	.formforge-cal-time-col { width: 56px; font-size: 11px; }
	.formforge-cal-cell     { height: 32px; font-size: 11px; }
	.formforge-calendar-nav { flex-wrap: wrap; }
	.formforge-cal-title    { width: 100%; order: -1; margin-bottom: 4px; }
}

/* ================================================
   CALENDRIER MODE RANGE — vue mensuelle
   ================================================ */

.formforge-calendar-range .formforge-calendar-nav {
	border-radius: 8px 8px 0 0;
	border: 1px solid #e5e5e5;
	border-bottom: none;
}
.formforge-month-grid {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
	border: 1px solid #e5e5e5;
	border-radius: 0 0 8px 8px;
	overflow: hidden;
	table-layout: fixed;
}
.formforge-month-grid thead th {
	background: #f6f7f7;
	border-bottom: 2px solid #c3c4c7;
	padding: 8px 4px;
	font-size: 11px;
	color: #50575e;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 500;
	text-align: center;
}
.formforge-month-cell {
	border: 1px solid #f0f0f1;
	height: 70px;
	padding: 6px 8px;
	vertical-align: top;
	font-size: 14px;
	transition: background 0.15s, transform 0.05s;
	user-select: none;
	position: relative;
}
.formforge-month-num {
	display: block;
	font-weight: 500;
}
.formforge-month-cell.is-other-month {
	color: #c0c0c0;
	background: #fafafa;
}
.formforge-month-cell.is-other-month .formforge-month-num { font-weight: 400; }
.formforge-month-cell.is-today {
	box-shadow: inset 0 0 0 2px #2271b1;
}
.formforge-month-cell.is-today .formforge-month-num {
	color: #2271b1;
	font-weight: 700;
}
.formforge-month-cell.is-available {
	background: #d1e7dd;
	color: #0a3622;
	cursor: pointer;
}
.formforge-month-cell.is-available:hover,
.formforge-month-cell.is-available:focus-visible {
	background: #a3cfbb;
	transform: scale( 0.98 );
	outline: none;
}
.formforge-month-cell.is-taken {
	background: #f8d7da;
	color: #58151c;
	cursor: not-allowed;
}
.formforge-month-cell.is-unavailable {
	background: #fff8e5;
	color: #8a6500;
	cursor: not-allowed;
}
.formforge-month-cell.is-unavailable.is-vacation {
	background: #ffe8d6;
	color: #9a4d00;
}
.formforge-month-cell.is-past {
	background: #fafafa;
	background-image: repeating-linear-gradient(
		135deg,
		transparent,
		transparent 4px,
		rgba( 0, 0, 0, 0.04 ) 4px,
		rgba( 0, 0, 0, 0.04 ) 5px
	);
	color: #bbb;
	cursor: default;
}
.formforge-month-cell.is-selected-start {
	background: #2271b1 !important;
	color: #fff !important;
	font-weight: 700;
	box-shadow: inset 0 0 0 2px #135e96;
}
.formforge-month-cell.is-in-selection {
	background: #c5dffd !important;
	color: #135e96 !important;
}

/* Mode time_range : sélection sur la grille hebdomadaire (mêmes états que la grille mensuelle). */
.formforge-cal-cell.is-selected-start {
	background: #2271b1 !important;
	color: #fff !important;
	font-weight: 700;
	box-shadow: inset 0 0 0 2px #135e96;
}
.formforge-cal-cell.is-in-selection {
	background: #c5dffd !important;
	color: #135e96 !important;
}

@media (max-width: 700px) {
	.formforge-month-cell { height: 50px; font-size: 12px; padding: 4px; }
}

.formforge-help {
	display: block;
	color: #666;
	font-size: 12px;
	margin-top: 4px;
}
.formforge-errors {
	margin: 6px 0 0;
	padding: 0 0 0 18px;
	color: #d63638;
	font-size: 13px;
}

/* Boutons */
.formforge-page-nav {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	margin-top: 24px;
}
.formforge-page-nav button {
	background: var(--ff-color-primary);
	color: #fff;
	border: none;
	padding: var(--ff-button-padding-y) var(--ff-button-padding-x);
	font-size: var(--ff-font-size);
	font-weight: 500;
	border-radius: var(--ff-radius);
	cursor: pointer;
	transition: background 0.15s;
	font-family: inherit;
}
.formforge-page-nav button:hover { background: var(--ff-color-primary-dark); }
.formforge-page-nav .formforge-prev {
	background: color-mix(in srgb, var(--ff-color-text) 8%, transparent);
	color: var(--ff-color-text);
}
.formforge-page-nav .formforge-prev:hover {
	background: color-mix(in srgb, var(--ff-color-text) 16%, transparent);
}
.formforge-submit-button {
	background: var(--ff-color-primary);
	color: #fff;
	border: none;
	padding: var(--ff-button-padding-y) var(--ff-button-padding-x);
	font-size: var(--ff-font-size);
	font-weight: 500;
	border-radius: var(--ff-radius);
	cursor: pointer;
	font-family: inherit;
}
.formforge-submit-button:hover { background: var(--ff-color-primary-dark); }

/* Confirmation / erreurs globales */
.formforge-confirmation {
	max-width: var(--ff-form-max-width);
	margin: 0 auto;
	padding: 18px 20px;
	background: #d1e7dd;
	color: #0a3622;
	border: 1px solid #a3cfbb;
	border-radius: calc(var(--ff-radius) * 1.5);
	font-size: calc(var(--ff-font-size) + 1px);
	font-family: var(--ff-font-family);
}
.formforge-global-error {
	max-width: 720px;
	margin: 0 auto 12px;
	padding: 12px 16px;
	background: #f8d7da;
	color: #58151c;
	border: 1px solid #f1aeb5;
	border-radius: 6px;
}
.formforge-global-error ul { margin: 0; padding-left: 18px; }

.formforge-error {
	padding: 12px;
	background: #fff3cd;
	color: #664d03;
	border: 1px solid #ffe69c;
	border-radius: 4px;
}

/* ================================================
   SAVE & CONTINUE LATER (bouton + modal)
   ================================================ */
.formforge-save-continue-trigger {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	margin: 0 0 12px;
	float: right;
	background: transparent;
	color: var(--ff-color-primary, #2271b1);
	border: 1px solid var(--ff-color-primary, #2271b1);
	border-radius: var(--ff-radius, 6px);
	font-size: 13px;
	cursor: pointer;
	font-family: inherit;
	transition: background 0.15s ease, color 0.15s ease;
}
.formforge-save-continue-trigger:hover {
	background: var(--ff-color-primary, #2271b1);
	color: #fff;
}
.formforge-resumed-notice {
	margin: 0 0 12px;
	padding: 10px 14px;
	background: #ecfdf5;
	color: #065f46;
	border: 1px solid #6ee7b7;
	border-radius: var(--ff-radius, 6px);
	font-size: 13px;
}
.formforge-sc-overlay {
	position: fixed;
	inset: 0;
	background: rgba(17, 24, 39, 0.5);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 999999;
	padding: 16px;
}
.formforge-sc-modal {
	background: #fff;
	border-radius: 10px;
	padding: 28px 28px 22px;
	max-width: 480px;
	width: 100%;
	box-shadow: 0 24px 48px rgba(0, 0, 0, 0.2);
	position: relative;
	font-family: inherit;
}
.formforge-sc-modal h3 {
	margin: 0 0 8px;
	font-size: 19px;
	color: #111827;
}
.formforge-sc-modal p {
	margin: 0 0 14px;
	font-size: 14px;
	color: #4b5563;
	line-height: 1.5;
}
.formforge-sc-close {
	position: absolute;
	top: 8px;
	right: 12px;
	background: none;
	border: none;
	font-size: 26px;
	line-height: 1;
	color: #9ca3af;
	cursor: pointer;
	padding: 4px 8px;
}
.formforge-sc-close:hover { color: #111827; }
.formforge-sc-label {
	display: block;
	font-size: 13px;
	font-weight: 500;
	color: #374151;
	margin-bottom: 14px;
}
.formforge-sc-email {
	display: block;
	width: 100%;
	margin-top: 4px;
	padding: 10px 12px;
	border: 1px solid #d1d5db;
	border-radius: 6px;
	font-size: 14px;
	font-family: inherit;
}
.formforge-sc-email:focus {
	outline: none;
	border-color: #2271b1;
	box-shadow: 0 0 0 3px rgba(34, 113, 177, 0.15);
}
.formforge-sc-actions {
	display: flex;
	gap: 8px;
	justify-content: flex-end;
	margin-top: 8px;
}
.formforge-sc-cancel,
.formforge-sc-submit {
	padding: 8px 16px;
	border-radius: 6px;
	font-size: 14px;
	cursor: pointer;
	font-family: inherit;
	border: 1px solid transparent;
}
.formforge-sc-cancel {
	background: #fff;
	color: #4b5563;
	border-color: #d1d5db;
}
.formforge-sc-cancel:hover { background: #f9fafb; }
.formforge-sc-submit {
	background: #2271b1;
	color: #fff;
}
.formforge-sc-submit:hover { background: #135e96; }
.formforge-sc-submit:disabled { opacity: 0.6; cursor: wait; }
.formforge-sc-message {
	margin: 12px 0 0;
	font-size: 13px;
	color: #6b7280;
	min-height: 18px;
}
.formforge-sc-message.is-success { color: #065f46; font-weight: 500; }
.formforge-sc-message.is-error   { color: #b91c1c; font-weight: 500; }

/* ================================================
   QUIZ / SCORING — bloc de résultat post-soumission
   ================================================ */
.formforge-quiz-result {
	max-width: var(--ff-form-max-width, 640px);
	margin: 0 auto;
	padding: 28px 32px;
	background: linear-gradient(135deg, #ecfdf5 0%, #f0f9ff 100%);
	border: 1px solid #a7f3d0;
	border-radius: var(--ff-radius, 8px);
	text-align: center;
	font-family: inherit;
}
.formforge-quiz-score {
	font-size: 48px;
	font-weight: 700;
	color: #047857;
	margin-bottom: 8px;
	letter-spacing: -1px;
}
.formforge-quiz-score-num { color: #047857; }
.formforge-quiz-score-max { color: #6b7280; font-size: 28px; font-weight: 500; }
.formforge-quiz-tier-title {
	margin: 8px 0 12px;
	font-size: 22px;
	color: #111827;
}
.formforge-quiz-tier-message {
	font-size: 15px;
	color: #4b5563;
	line-height: 1.55;
	text-align: left;
	margin: 12px auto 0;
	max-width: 540px;
}

/* Bloc Gutenberg preview */
.formforge-block-preview {
	padding: 20px;
	background: #f6f7f7;
	border: 1px dashed #c3c4c7;
	border-radius: 4px;
}
.formforge-block-shortcode {
	margin-top: 8px;
	font-family: monospace;
	font-size: 12px;
	color: #555;
}
