/**
 * Z2W Forms — Public Form Styles
 *
 * Mobile-first, accessible, designed to work with most WordPress themes.
 * Uses CSS custom properties (--z2w-*) for dynamic styling from admin controls.
 * All properties have sensible fallback values.
 *
 * @package Z2W_Forms
 */

/* ─── Container ─── */

.z2w-forms-container {
	max-width: var(--z2w-form-max-width, 680px);
	margin: 0 auto;
	padding: var(--z2w-form-padding, 0);
	background: var(--z2w-form-bg, transparent);
	border-radius: var(--z2w-form-border-radius, 0px);
	border: var(--z2w-form-border-width, 0) solid var(--z2w-form-border-color, transparent);
	box-shadow: var(--z2w-form-shadow, none);
	font-family: var(--z2w-font-family, inherit);
}

/* ─── Messages ─── */

.z2w-form-message {
	padding: 14px 18px;
	border-radius: var(--z2w-border-radius, 6px);
	margin-bottom: 20px;
	font-size: 15px;
	line-height: 1.5;
}

.z2w-form-message--success {
	background: #ecfdf5;
	border: 1px solid #a7f3d0;
	color: #065f46;
}

.z2w-form-message--error {
	background: #fef2f2;
	border: 1px solid #fecaca;
	color: #991b1b;
}

.z2w-form-message--info {
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	color: #1e40af;
}

.z2w-form-message a {
	color: inherit;
	text-decoration: underline;
	font-weight: 500;
}

.z2w-form-message a:hover {
	text-decoration: none;
}

/* ─── Form Layout (12-column CSS Grid) ─── */

.z2w-form {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: var(--z2w-field-gap, 18px);
}

/* ─── Honeypot (visually hidden, screen-reader hidden) ─── */

.z2w-form-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
}

/* ─── Cloudflare Turnstile (above Next/Submit). No min-height: invisible mode stays tight; visible iframe sets its own height. ─── */

.z2w-form-field.z2w-form-turnstile {
	grid-column: 1 / -1;
	margin: 0 0 10px;
	min-height: 0;
}

.z2w-form-field.z2w-form-turnstile .cf-turnstile {
	display: block;
	min-height: 0;
}

/* ─── Multi-step Progress Bar ─── */

.z2w-progress-bar {
	grid-column: 1 / -1;
	margin-bottom: 24px;
}

.z2w-progress-track {
	height: 6px;
	background: #e5e7eb;
	border-radius: 3px;
	overflow: hidden;
	margin-bottom: 12px;
}

.z2w-progress-fill {
	height: 100%;
	background: var(--z2w-color-primary, #2563eb);
	border-radius: 3px;
	transition: width 0.3s ease;
}

.z2w-progress-steps {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	font-size: 13px;
	color: #6b7280;
}

.z2w-progress-step {
	transition: color 0.2s;
}

.z2w-progress-step--active {
	color: var(--z2w-color-primary, #2563eb);
	font-weight: 600;
}

.z2w-progress-step--completed {
	color: #059669;
}

/* ─── Multi-step Navigation ─── */

.z2w-form-step-nav {
	grid-column: 1 / -1;
	display: flex;
	gap: 12px;
	align-items: center;
	margin-top: 12px;
}

.z2w-form-step-nav .z2w-btn-prev,
.z2w-form-step-nav .z2w-btn-next {
	padding: 10px 20px;
	border-radius: var(--z2w-border-radius, 6px);
	background: #f3f4f6;
	border: 1px solid #d1d5db;
	color: #374151;
	cursor: pointer;
	font-size: 15px;
	transition: background 0.2s;
}

.z2w-form-step-nav .z2w-btn-prev:hover,
.z2w-form-step-nav .z2w-btn-next:hover {
	background: #e5e7eb;
}

.z2w-form-step-nav .z2w-btn-submit {
	/* Uses .z2w-form-button styles from parent */
}

.z2w-form-secondary-nav {
	grid-column: 1 / -1;
	display: flex;
	gap: 12px;
	align-items: center;
	justify-content: center;
	margin-top: 8px;
}

.z2w-form-step {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: var(--z2w-field-gap, 18px);
}

.z2w-form-step .z2w-step-title {
	grid-column: 1 / -1;
	margin: 0 0 16px 0;
	font-size: 18px;
	font-weight: 600;
	color: var(--z2w-color-label, #374151);
}

/* ─── Fields — grid-column widths ─── */

.z2w-form-field {
	grid-column: span 12;
}

.z2w-form-field--half {
	grid-column: span 6;
}

.z2w-form-field--third {
	grid-column: span 4;
}

.z2w-form-field--two-thirds {
	grid-column: span 8;
}

.z2w-form-field--quarter {
	grid-column: span 3;
}

.z2w-form-field--three-quarters {
	grid-column: span 9;
}

.z2w-form-field label {
	display: block;
	margin-bottom: var(--z2w-label-gap, 6px);
	font-weight: 600;
	font-size: var(--z2w-font-size-label, 14px);
	color: var(--z2w-color-label, #374151);
}

.z2w-required {
	color: var(--z2w-color-error, #dc2626);
	margin-left: 2px;
}

.z2w-form-field input[type="text"],
.z2w-form-field input[type="email"],
.z2w-form-field input[type="tel"],
.z2w-form-field input[type="url"],
.z2w-form-field input[type="number"],
.z2w-form-field input[type="date"],
.z2w-form-field textarea,
.z2w-form-field select {
	display: block;
	width: 100%;
	padding: 10px 14px;
	font-size: var(--z2w-font-size-input, 16px);
	line-height: 1.5;
	color: var(--z2w-color-input-text, #111827);
	background: var(--z2w-color-input-bg, #fff);
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
	font-family: inherit;
}

.z2w-form-field textarea {
	min-height: 80px;
	resize: vertical;
}

.z2w-form-field select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23374151' d='M1.41 0L6 4.58 10.59 0 12 1.41l-6 6-6-6z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 36px;
}

.z2w-form-field input:focus,
.z2w-form-field textarea:focus,
.z2w-form-field select:focus {
	outline: none;
	border-color: var(--z2w-color-primary, #2563eb);
	box-shadow: 0 0 0 3px var(--z2w-color-focus-ring, rgba(37, 99, 235, 0.15));
}

.z2w-form-field input:focus-visible,
.z2w-form-field textarea:focus-visible,
.z2w-form-field select:focus-visible {
	outline: none;
	border-color: var(--z2w-color-primary, #2563eb);
	box-shadow: 0 0 0 3px var(--z2w-color-focus-ring, rgba(37, 99, 235, 0.15));
}

.z2w-form-field input.z2w-field-error,
.z2w-form-field textarea.z2w-field-error,
.z2w-form-field select.z2w-field-error {
	border-color: #ef4444;
}

.z2w-form-field input.z2w-field-error:focus,
.z2w-form-field textarea.z2w-field-error:focus,
.z2w-form-field select.z2w-field-error:focus {
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}

/* ─── Checkbox ─── */

.z2w-form-field--checkbox {
	display: flex;
	align-items: flex-start;
}

.z2w-checkbox-label {
	display: flex !important;
	align-items: center;
	gap: 8px;
	font-weight: 400 !important;
	cursor: pointer;
}

.z2w-checkbox-label input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin: 0;
	flex-shrink: 0;
	accent-color: var(--z2w-color-primary, #2563eb);
	cursor: pointer;
}

.z2w-checkbox-label input[type="checkbox"]:focus-visible {
	outline: 2px solid var(--z2w-color-primary, #2563eb);
	outline-offset: 2px;
}

/* ─── Submit Button ─── */

.z2w-form-field--page-break {
	grid-column: 1 / -1;
	display: none;
}

.z2w-form-submit {
	grid-column: 1 / -1;
	width: 100%;
	padding-top: 4px;
	display: flex;
	justify-content: center;
}

.z2w-form-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: var(--z2w-button-width, 100%);
	padding: 12px 24px;
	font-size: var(--z2w-font-size-input, 16px);
	font-weight: 600;
	line-height: 1.5;
	color: var(--z2w-color-button-text, #fff);
	background: var(--z2w-color-button-bg, var(--z2w-color-primary, #2563eb));
	border: none;
	border-radius: var(--z2w-button-border-radius, var(--z2w-border-radius, 6px));
	cursor: pointer;
	transition: background-color 0.15s ease, transform 0.1s ease;
	-webkit-appearance: none;
	appearance: none;
	font-family: inherit;
}

.z2w-form-button:hover {
	background: var(--z2w-color-button-hover, #1d4ed8);
}

.z2w-form-button:focus-visible {
	outline: 2px solid var(--z2w-color-primary, #2563eb);
	outline-offset: 2px;
}

.z2w-form-button:active {
	transform: scale(0.98);
}

/* ─── Loading State ─── */

.z2w-form-button.z2w-loading {
	opacity: 0.75;
	cursor: not-allowed;
	pointer-events: none;
}

.z2w-btn-spinner {
	display: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: #fff;
	border-radius: 50%;
	animation: z2w-spin 0.6s linear infinite;
}

.z2w-loading .z2w-btn-spinner {
	display: inline-block;
}

@keyframes z2w-spin {
	to {
		transform: rotate(360deg);
	}
}

/* ─── Radio Buttons ─── */

.z2w-form-field--radio fieldset {
	border: none;
	padding: 0;
	margin: 0;
}

.z2w-form-field--radio legend {
	display: block;
	margin-bottom: var(--z2w-label-gap, 6px);
	font-weight: 600;
	font-size: var(--z2w-font-size-label, 14px);
	color: var(--z2w-color-label, #374151);
	padding: 0;
}

.z2w-radio-group {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.z2w-radio-group--inline {
	flex-direction: row;
	flex-wrap: wrap;
	gap: 12px;
}

.z2w-radio-label {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 400;
	font-size: var(--z2w-font-size-input, 16px);
	cursor: pointer;
	color: var(--z2w-color-input-text, #111827);
}

.z2w-radio-label input[type="radio"] {
	width: 18px;
	height: 18px;
	margin: 0;
	flex-shrink: 0;
	accent-color: var(--z2w-color-primary, #2563eb);
	cursor: pointer;
}

.z2w-radio-label input[type="radio"]:focus-visible {
	outline: 2px solid var(--z2w-color-primary, #2563eb);
	outline-offset: 2px;
}

/* ─── Address Composite Field ─── */

.z2w-address-group-label {
	font-weight: 600;
	font-size: var(--z2w-font-size-label, 14px);
	color: var(--z2w-color-label, #374151);
	margin-bottom: 8px;
}

.z2w-address-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 16px;
}

.z2w-address-sub-field label {
	display: block;
	font-weight: 500;
	font-size: calc(var(--z2w-font-size-label, 14px) - 1px);
	color: var(--z2w-color-label, #374151);
	margin-bottom: 4px;
}

.z2w-address-sub-field input[type="text"] {
	display: block;
	width: 100%;
	padding: 10px 14px;
	font-size: var(--z2w-font-size-input, 16px);
	line-height: 1.5;
	color: var(--z2w-color-input-text, #111827);
	background: var(--z2w-color-input-bg, #fff);
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	font-family: inherit;
}

.z2w-address-sub-field input[type="text"]:focus {
	outline: none;
	border-color: var(--z2w-color-primary, #2563eb);
	box-shadow: 0 0 0 3px var(--z2w-color-focus-ring, rgba(37, 99, 235, 0.15));
}

@media (max-width: 480px) {
	.z2w-address-grid {
		grid-template-columns: 1fr;
	}
}

/* ─── Country Combobox ─── */

.z2w-country-wrapper {
	position: relative;
}

.z2w-country-search {
	display: block;
	width: 100%;
	padding: 10px 14px;
	font-size: var(--z2w-font-size-input, 16px);
	line-height: 1.5;
	color: var(--z2w-color-input-text, #111827);
	background: var(--z2w-color-input-bg, #fff);
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
	font-family: inherit;
}

.z2w-country-search:focus {
	outline: none;
	border-color: var(--z2w-color-primary, #2563eb);
	box-shadow: 0 0 0 3px var(--z2w-color-focus-ring, rgba(37, 99, 235, 0.15));
}

.z2w-country-listbox {
	position: absolute;
	top: calc(100% + 2px);
	left: 0;
	right: 0;
	z-index: 9999;
	max-height: min(50vh, 360px);
	overflow-y: auto;
	background: #fff;
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	list-style: none;
	margin: 0;
	padding: 4px 0;
}

.z2w-country-listbox[hidden] {
	display: none;
}

.z2w-country-listbox li {
	padding: 6px 8px;
	font-size: var(--z2w-font-size-input, 15px);
	cursor: pointer;
	color: var(--z2w-color-input-text, #111827);
	transition: background-color 0.1s ease;
}

.z2w-country-listbox li:hover,
.z2w-country-listbox li.z2w-country-active {
	background: var(--z2w-color-focus-ring, rgba(37, 99, 235, 0.08));
	color: var(--z2w-color-primary, #2563eb);
}

/* ─── Date & Number ─── */

.z2w-form-field input[type="date"] {
	cursor: pointer;
}

.z2w-form-field input[type="number"] {
	-moz-appearance: textfield;
}

.z2w-form-field input[type="number"]::-webkit-inner-spin-button,
.z2w-form-field input[type="number"]::-webkit-outer-spin-button {
	opacity: 1;
}

/* ─── Dark Mode ─── */

/*
 * When dark_mode = 'auto': respect OS preference.
 * When dark_mode = 'dark': always dark (class applied by PHP).
 * Dynamic dark-mode colors are output via wp_add_inline_style() with
 * data-dark-mode="auto|dark" selectors — these rules provide CSS variable
 * fall-backs when no inline overrides are present (e.g. fresh install).
 */

@media (prefers-color-scheme: dark) {
	.z2w-forms-container[data-dark-mode="auto"] {
		--z2w-form-bg: #1f2937;
		--z2w-color-primary: #3b82f6;
		--z2w-color-label: #d1d5db;
		--z2w-color-input-text: #f9fafb;
		--z2w-color-input-bg: #374151;
		--z2w-color-input-border: #4b5563;
		--z2w-color-button-text: #ffffff;
		--z2w-color-button-bg: #3b82f6;
		--z2w-color-button-hover: #2563eb;
		--z2w-color-focus-ring: rgba(59, 130, 246, 0.25);
		--z2w-color-error: #f87171;
		background: var(--z2w-form-bg);
	}
}

.z2w-forms-container[data-dark-mode="dark"] {
	--z2w-form-bg: #1f2937;
	--z2w-color-primary: #3b82f6;
	--z2w-color-label: #d1d5db;
	--z2w-color-input-text: #f9fafb;
	--z2w-color-input-bg: #374151;
	--z2w-color-input-border: #4b5563;
	--z2w-color-button-text: #ffffff;
	--z2w-color-button-bg: #3b82f6;
	--z2w-color-button-hover: #2563eb;
	--z2w-color-focus-ring: rgba(59, 130, 246, 0.25);
	--z2w-color-error: #f87171;
	background: var(--z2w-form-bg);
}

/* Country listbox needs explicit bg in dark mode */
@media (prefers-color-scheme: dark) {
	.z2w-forms-container[data-dark-mode="auto"] .z2w-country-listbox {
		background: #374151;
		border-color: #4b5563;
	}
}
.z2w-forms-container[data-dark-mode="dark"] .z2w-country-listbox {
	background: #374151;
	border-color: #4b5563;
}

/* ─── Responsive ─── */

@media (max-width: 480px) {
	.z2w-form-field--half,
	.z2w-form-field--third,
	.z2w-form-field--two-thirds,
	.z2w-form-field--quarter,
	.z2w-form-field--three-quarters {
		grid-column: span 12;
	}

	.z2w-form-field input,
	.z2w-form-field textarea,
	.z2w-form-field select,
	.z2w-country-search {
		font-size: 16px; /* Prevents iOS auto-zoom on input focus */
	}

	.z2w-radio-group--inline {
		flex-direction: column;
	}
}

/* ─── Conditional Display Logic ─── */

/* Fields hidden by conditional logic — removed from flow immediately */
.z2w-field-hidden {
	display: none !important;
}

/* Slide-in animation when a hidden field becomes visible */
@keyframes z2w-field-in {
	from {
		opacity: 0;
		transform: translateY(-6px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.z2w-field-appearing {
	animation: z2w-field-in 0.2s ease-out both;
}

/* ─── File Upload Zone ─── */

.z2w-form-field--file .z2w-file-upload-zone {
	border: 2px dashed var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	background: var(--z2w-color-input-bg, #ffffff);
	padding: 16px 20px;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease;
	position: relative;
}

.z2w-form-field--file .z2w-file-upload-zone:hover,
.z2w-form-field--file .z2w-file-upload-zone:focus {
	border-color: var(--z2w-color-primary, #2563eb);
	outline: none;
}

.z2w-form-field--file .z2w-file-upload-zone--drag-over {
	border-color: var(--z2w-color-primary, #2563eb);
	background: color-mix(in srgb, var(--z2w-color-primary, #2563eb) 6%, var(--z2w-color-input-bg, #ffffff));
}

.z2w-form-field--file .z2w-file-upload-zone-inner {
	display: flex;
	align-items: center;
	gap: 20px;
}

.z2w-form-field--file .z2w-file-upload-icon {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--z2w-color-primary, #2563eb);
	opacity: 0.7;
	flex: 1;
	min-width: 0;
}

.z2w-form-field--file .z2w-file-upload-icon svg {
	flex-shrink: 0;
}

.z2w-form-field--file .z2w-file-upload-drag-text {
	margin: 0;
	font-size: var(--z2w-font-size-input, 15px);
	color: var(--z2w-color-input-text, #1a1a1a);
	font-weight: 500;
	white-space: nowrap;
}

.z2w-form-field--file .z2w-file-upload-action {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
}

.z2w-form-field--file .z2w-file-upload-btn {
	display: inline-block;
	padding: 8px 18px;
	background: var(--z2w-color-button-bg, var(--z2w-color-primary, #2563eb));
	color: var(--z2w-color-button-text, #ffffff);
	border: none;
	border-radius: var(--z2w-button-border-radius, 6px);
	font-size: var(--z2w-font-size-input, 15px);
	cursor: pointer;
	transition: background 0.15s ease;
	white-space: nowrap;
}

.z2w-form-field--file .z2w-file-upload-btn:hover {
	background: var(--z2w-color-button-hover, #1d4ed8);
}

.z2w-form-field--file .z2w-file-upload-hint {
	margin: 0;
	font-size: 12px;
	color: var(--z2w-color-label, #374151);
	opacity: 0.55;
	white-space: nowrap;
}

@media (max-width: 480px) {
	.z2w-form-field--file .z2w-file-upload-zone-inner {
		flex-direction: column;
		text-align: center;
		gap: 12px;
	}
	.z2w-form-field--file .z2w-file-upload-icon {
		flex-direction: column;
		gap: 6px;
	}
}

/* ─── File Preview List ─── */

.z2w-file-preview-list {
	margin-top: 12px;
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.z2w-file-preview-item {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--z2w-color-input-bg, #f9fafb);
	border: 1px solid var(--z2w-color-input-border, #e5e7eb);
	border-radius: var(--z2w-border-radius, 6px);
	padding: 10px 12px;
	font-size: 14px;
	max-width: 100%;
}

.z2w-file-preview-thumb {
	width: 56px;
	height: 56px;
	object-fit: cover;
	border-radius: 4px;
	flex-shrink: 0;
}

.z2w-file-preview-icon {
	width: 56px;
	height: 56px;
	line-height: 56px;
	text-align: center;
	flex-shrink: 0;
	color: var(--z2w-color-primary, #2563eb);
	font-size: 28px !important;
}

.z2w-file-preview-name {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: var(--z2w-color-input-text, #1a1a1a);
	font-size: 14px;
	min-width: 0;
}

.z2w-file-preview-size {
	font-size: 12px;
	color: var(--z2w-color-label, #374151);
	opacity: 0.6;
	white-space: nowrap;
	flex-shrink: 0;
}

.z2w-file-preview-remove {
	background: none;
	border: none;
	cursor: pointer;
	color: #ef4444;
	font-size: 18px;
	line-height: 1;
	padding: 0 2px;
	flex-shrink: 0;
	opacity: 0.7;
	transition: opacity 0.1s;
}

.z2w-file-preview-remove:hover {
	opacity: 1;
}

/* ─── Upload Progress ─── */

.z2w-file-progress {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-top: 8px;
}

.z2w-file-progress-bar {
	flex: 1;
	height: 6px;
	background: var(--z2w-color-input-border, #e5e7eb);
	border-radius: 3px;
	overflow: hidden;
	position: relative;
}

.z2w-file-progress-bar::after {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: var(--progress, 0%);
	background: var(--z2w-color-primary, #2563eb);
	transition: width 0.1s linear;
}

.z2w-file-progress-text {
	font-size: 12px;
	color: var(--z2w-color-label, #374151);
	white-space: nowrap;
}

.z2w-file-error-msg {
	margin-top: 6px;
	font-size: 13px;
	color: #dc2626;
	min-height: 0;
}

/* ─── Repeater Fields ─── */

.z2w-form-field--repeater {
	grid-column: span 12;
}

.z2w-repeater-group-label {
	font-weight: 600;
	font-size: var(--z2w-font-size-label, 14px);
	color: var(--z2w-color-label, #374151);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 4px;
}

.z2w-repeater-rows {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.z2w-repeater-row {
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	padding: 16px;
	background: var(--z2w-color-input-bg, #fafafa);
	position: relative;
}

.z2w-repeater-row-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 12px;
}

.z2w-repeater-row-number {
	font-size: 12px;
	font-weight: 600;
	color: var(--z2w-color-label, #6b7280);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.z2w-repeater-remove {
	background: none;
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: 4px;
	width: 28px;
	height: 28px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	line-height: 1;
	color: var(--z2w-color-label, #6b7280);
	transition: border-color 0.15s, color 0.15s;
	padding: 0;
}

.z2w-repeater-remove:hover:not(:disabled) {
	border-color: #ef4444;
	color: #ef4444;
}

.z2w-repeater-remove:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.z2w-repeater-row-fields {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: var(--z2w-field-gap, 14px);
}

.z2w-repeater-row-fields .z2w-form-field {
	margin-bottom: 0;
}

.z2w-repeater-add-row {
	margin-top: 4px;
	background: none;
	border: 1px dashed var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	padding: 10px 18px;
	width: 100%;
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	color: var(--z2w-color-primary, #2563eb);
	transition: border-color 0.15s, background 0.15s;
	text-align: center;
}

.z2w-repeater-add-row:hover {
	border-color: var(--z2w-color-primary, #2563eb);
	background: color-mix(in srgb, var(--z2w-color-primary, #2563eb) 5%, transparent);
}

@media (max-width: 480px) {
	.z2w-repeater-row-fields .z2w-form-field--half,
	.z2w-repeater-row-fields .z2w-form-field--third,
	.z2w-repeater-row-fields .z2w-form-field--two-thirds,
	.z2w-repeater-row-fields .z2w-form-field--quarter,
	.z2w-repeater-row-fields .z2w-form-field--three-quarters {
		grid-column: span 12;
	}
}

/* ============================================================
   Signature Field
   ============================================================ */

.z2w-form-field--signature .z2w-signature-wrap {
	border: 2px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: var(--z2w-border-radius, 6px);
	background: var(--z2w-color-input-bg, #ffffff);
	overflow: hidden;
	position: relative;
	cursor: crosshair;
}

.z2w-form-field--signature .z2w-signature-canvas {
	display: block;
	width: 100%;
	height: 150px;
	touch-action: none;
}

.z2w-form-field--signature .z2w-signature-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 6px 10px;
	border-top: 1px solid var(--z2w-color-input-border, #d1d5db);
	background: var(--z2w-color-input-bg, #ffffff);
}

.z2w-form-field--signature .z2w-signature-clear {
	background: none;
	border: 1px solid var(--z2w-color-input-border, #d1d5db);
	border-radius: 4px;
	padding: 4px 12px;
	cursor: pointer;
	font-size: 12px;
	color: var(--z2w-color-label, #6b7280);
	transition: border-color 0.15s, color 0.15s;
}

.z2w-form-field--signature .z2w-signature-clear:hover {
	border-color: #ef4444;
	color: #ef4444;
}

.z2w-form-field--signature .z2w-signature-hint {
	font-size: 12px;
	color: var(--z2w-color-label, #9ca3af);
	font-style: italic;
}

.z2w-form-field--signature .z2w-signature-wrap.z2w-signature-has-content .z2w-signature-hint {
	display: none;
}

.z2w-form-field--signature .z2w-signature-required-error {
	font-size: 13px;
	color: #ef4444;
	margin-top: 4px;
}

/* Dark mode overrides for signature field */
@media (prefers-color-scheme: dark) {
	[data-dark-mode="auto"] .z2w-signature-canvas,
	[data-dark-mode="dark"] .z2w-signature-canvas {
		background: var(--z2w-dark-color-input-bg, #374151);
	}
}

/* -------------------------------------------------------
 * Save & Continue Later — Draft Saver
 * ----------------------------------------------------- */
.z2w-save-draft-btn {
	display: inline-block;
	padding: 8px 16px;
	font-size: 13px;
	line-height: 1.4;
	color: var(--z2w-color-primary, #2563eb);
	background: transparent;
	border: 1px solid var(--z2w-color-primary, #2563eb);
	border-radius: var(--z2w-border-radius, 6px);
	cursor: pointer;
	transition: all 0.2s ease;
}

.z2w-save-draft-btn:hover {
	background: var(--z2w-color-primary, #2563eb);
	color: #fff;
}

.z2w-save-draft-btn.z2w-draft-saved {
	border-color: #16a34a;
	color: #16a34a;
}

.z2w-draft-notice {
	grid-column: 1 / -1;
	background: #f0f9ff;
	border: 1px solid #bae6fd;
	border-radius: var(--z2w-border-radius, 6px);
	padding: 10px 14px;
	margin-bottom: 16px;
	font-size: 13px;
	color: #0c4a6e;
}

.z2w-draft-notice.z2w-draft-restored {
	background: #f0fdf4;
	border-color: #bbf7d0;
	color: #166534;
}

.z2w-draft-notice p {
	margin: 0 0 6px;
}

.z2w-draft-resume-url {
	width: 100%;
	padding: 6px 8px;
	font-size: 12px;
	border: 1px solid #d1d5db;
	border-radius: 4px;
	background: #fff;
	color: #374151;
	cursor: text;
}

.z2w-clear-draft-btn {
	background: none;
	border: none;
	text-decoration: underline;
	cursor: pointer;
	font-size: inherit;
	color: inherit;
	padding: 0;
}

.z2w-clear-draft-btn:hover {
	opacity: 0.7;
}

/* ─── Offline / PWA ─── */

.z2w-offline-banner {
	background: #fef3c7;
	border: 1px solid #fbbf24;
	border-radius: var(--z2w-border-radius, 6px);
	padding: 10px 14px;
	margin-bottom: 16px;
	font-size: 14px;
	color: #92400e;
	display: flex;
	align-items: center;
	gap: 8px;
	animation: z2w-field-in 0.3s ease;
}

.z2w-offline-icon {
	color: #f59e0b;
	font-size: 10px;
}

.z2w-offline-queue-badge {
	background: #eff6ff;
	border: 1px solid #93c5fd;
	border-radius: var(--z2w-border-radius, 6px);
	padding: 10px 14px;
	margin-bottom: 16px;
	font-size: 13px;
	color: #1e40af;
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}

.z2w-queue-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	border-radius: 11px;
	background: #3b82f6;
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	padding: 0 6px;
}

.z2w-sync-now-btn {
	background: none;
	border: 1px solid #3b82f6;
	color: #3b82f6;
	border-radius: 4px;
	padding: 4px 10px;
	font-size: 12px;
	cursor: pointer;
	margin-left: auto;
	transition: all 0.2s ease;
}

.z2w-sync-now-btn:hover {
	background: #3b82f6;
	color: #fff;
}

.z2w-sync-now-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.z2w-sync-toast {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: #059669;
	color: #fff;
	padding: 10px 20px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 500;
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
	opacity: 0;
	transition: opacity 0.3s ease, transform 0.3s ease;
	z-index: 99999;
	pointer-events: none;
}

.z2w-sync-toast--visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

/* Dark mode overrides for offline elements */
.z2w-forms-container[data-dark-mode="dark"] .z2w-offline-banner,
.z2w-forms-container[data-dark-mode="auto"] .z2w-offline-banner {
	background: #422006;
	border-color: #a16207;
	color: #fef3c7;
}

.z2w-forms-container[data-dark-mode="dark"] .z2w-offline-queue-badge,
.z2w-forms-container[data-dark-mode="auto"] .z2w-offline-queue-badge {
	background: #1e3a5f;
	border-color: #3b82f6;
	color: #bfdbfe;
}

@media (prefers-color-scheme: dark) {
	.z2w-forms-container[data-dark-mode="auto"] .z2w-offline-banner {
		background: #422006;
		border-color: #a16207;
		color: #fef3c7;
	}
	.z2w-forms-container[data-dark-mode="auto"] .z2w-offline-queue-badge {
		background: #1e3a5f;
		border-color: #3b82f6;
		color: #bfdbfe;
	}
}

/* -------------------------------------------------------
 * My Forms — Front-end Submissions List
 * ----------------------------------------------------- */
.z2w-my-forms {
	max-width: 1100px;
}

.z2w-my-forms-empty {
	padding: 24px;
	text-align: center;
	color: #6b7280;
	font-size: 15px;
}

.z2w-my-forms-login {
	padding: 24px;
	text-align: center;
	background: #f9fafb;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
}

.z2w-my-forms-login a {
	color: var(--z2w-color-primary, #2563eb);
	text-decoration: underline;
}

.z2w-my-forms-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 15px;
	line-height: 1.55;
}

.z2w-my-forms-table thead th {
	text-align: left;
	padding: 12px 14px;
	border-bottom: 2px solid #e5e7eb;
	font-weight: 600;
	color: #374151;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.z2w-my-forms-table tbody td {
	padding: 14px;
	border-bottom: 1px solid #f3f4f6;
	color: #374151;
	vertical-align: top;
}

.z2w-my-forms-table tbody tr:hover {
	background: #f9fafb;
}

.z2w-my-forms-status {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 12px;
	font-size: 12px;
	font-weight: 500;
	line-height: 1.6;
}

.z2w-my-forms-status--new {
	background: #dbeafe;
	color: #1e40af;
}

.z2w-my-forms-status--read,
.z2w-my-forms-status--starred {
	background: #d1fae5;
	color: #065f46;
}

.z2w-my-forms-pagination {
	display: flex;
	gap: 6px;
	margin-top: 16px;
	justify-content: center;
}

.z2w-my-forms-page {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 32px;
	height: 32px;
	padding: 0 8px;
	border: 1px solid #d1d5db;
	border-radius: 6px;
	font-size: 13px;
	color: #374151;
	text-decoration: none;
	transition: all 0.15s ease;
}

.z2w-my-forms-page:hover {
	background: #f3f4f6;
	border-color: #9ca3af;
}

.z2w-my-forms-page.current {
	background: var(--z2w-color-primary, #2563eb);
	color: #fff;
	border-color: var(--z2w-color-primary, #2563eb);
}

.z2w-my-forms-view,
.z2w-my-forms-action {
	color: #2563eb;
	text-decoration: none;
	font-weight: 500;
	font-size: 14px;
}

.z2w-my-forms-view:hover,
.z2w-my-forms-action:hover {
	text-decoration: underline;
}

.z2w-my-forms-actions-cell {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	align-items: center;
}

.z2w-my-forms-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
	flex-wrap: wrap;
	gap: 10px;
}

.z2w-my-forms-header h2 {
	margin: 0;
	font-size: 22px;
}

.z2w-my-forms-export-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 16px;
	background: #f3f4f6;
	border: 1px solid #d1d5db;
	border-radius: 6px;
	color: #374151;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	cursor: pointer;
	transition: all 0.15s ease;
}

.z2w-my-forms-export-btn:hover {
	background: #e5e7eb;
	border-color: #9ca3af;
	color: #111827;
}

.z2w-my-forms-export-btn svg {
	width: 16px;
	height: 16px;
}

/* ─── My Forms Detail View ─── */

.z2w-my-forms-detail-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
	flex-wrap: wrap;
	gap: 8px;
}

.z2w-my-forms-back {
	color: #2563eb;
	text-decoration: none;
	font-size: 14px;
}

.z2w-my-forms-back:hover {
	text-decoration: underline;
}

.z2w-my-forms-print {
	background: #2563eb;
	color: #fff;
	border: none;
	padding: 8px 16px;
	border-radius: 6px;
	font-size: 13px;
	cursor: pointer;
	transition: background 0.15s ease;
}

.z2w-my-forms-print:hover {
	background: #1d4ed8;
}

.z2w-my-forms-detail-date {
	color: #6b7280;
	font-size: 14px;
	margin-top: -8px;
	margin-bottom: 16px;
}

.z2w-my-forms-detail-table {
	width: 100%;
	border-collapse: collapse;
}

.z2w-my-forms-detail-table th {
	text-align: left;
	padding: 10px 12px;
	border-bottom: 1px solid #e5e7eb;
	font-weight: 600;
	color: #374151;
	width: 30%;
	vertical-align: top;
	font-size: 14px;
}

.z2w-my-forms-detail-table td {
	padding: 10px 12px;
	border-bottom: 1px solid #f3f4f6;
	color: #374151;
	font-size: 14px;
	word-break: break-word;
}

@media print {
	.z2w-my-forms-detail-header { display: none; }
	.z2w-my-forms-back { display: none; }
	.z2w-my-forms-detail-table { font-size: 12px; }
}

@media (max-width: 600px) {
	.z2w-my-forms-table thead {
		display: none;
	}
	.z2w-my-forms-table tbody tr {
		display: block;
		margin-bottom: 12px;
		border: 1px solid #e5e7eb;
		border-radius: 8px;
		padding: 12px;
	}
	.z2w-my-forms-table tbody td {
		display: block;
		padding: 4px 0;
		border-bottom: none;
	}
	.z2w-my-forms-table tbody td::before {
		content: attr(data-label) ": ";
		font-weight: 600;
		color: #1f2937;
	}
	.z2w-my-forms-detail-table th {
		width: auto;
		display: block;
		border-bottom: none;
		padding-bottom: 0;
	}
	.z2w-my-forms-detail-table td {
		display: block;
		padding-top: 2px;
	}
}

/* ============================================================
 * Re-submission workflow
 * ============================================================ */

/* "Request Edit" button in My Forms action column */
.z2w-rsub-request-btn {
	display: inline-block;
	padding: 4px 12px;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.5;
	color: #1d4ed8;
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	border-radius: 4px;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s;
}

.z2w-rsub-request-btn:hover:not(:disabled) {
	background: #dbeafe;
	border-color: #93c5fd;
}

.z2w-rsub-request-btn:disabled,
.z2w-rsub-request-btn.z2w-rsub-requested {
	opacity: 0.7;
	cursor: default;
}

/* Status badges used in My Forms table and re-submission detail */
.z2w-rsub-status {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 600;
	white-space: nowrap;
}

.z2w-rsub-status--pending {
	background: #fef9c3;
	color: #854d0e;
}

.z2w-rsub-status--approved {
	background: #d1fae5;
	color: #065f46;
}

.z2w-rsub-status--denied {
	background: #fee2e2;
	color: #991b1b;
}

.z2w-rsub-status--completed {
	background: #e0e7ff;
	color: #3730a3;
}

.z2w-rsub-status--maxed,
.z2w-rsub-status--expired {
	background: #f3f4f6;
	color: #6b7280;
	font-weight: 400;
}

/* Edit form wrapper */
.z2w-resubmit-edit-wrap {
	max-width: 780px;
}

.z2w-resubmit-edit-intro {
	background: #eff6ff;
	border-left: 4px solid #3b82f6;
	padding: 10px 14px;
	border-radius: 0 4px 4px 0;
	color: #1e40af;
	font-size: 14px;
	margin-bottom: 20px;
}

.z2w-resubmit-locked-note {
	background: #fefce8;
	border-left: 4px solid #eab308;
	padding: 8px 14px;
	border-radius: 0 4px 4px 0;
	font-size: 13px;
	color: #713f12;
	margin-bottom: 16px;
}

/* Notice helper (error/success blocks in My Forms context) */
.z2w-notice {
	padding: 10px 14px;
	border-radius: 4px;
	font-size: 14px;
	margin-bottom: 16px;
}

.z2w-notice--error {
	background: #fee2e2;
	color: #991b1b;
	border-left: 4px solid #ef4444;
}

.z2w-notice--success {
	background: #d1fae5;
	color: #065f46;
	border-left: 4px solid #10b981;
}

/* Download Form Preview button */
.z2w-docx-download {
	margin-top: 16px;
	text-align: center;
}

.z2w-docx-download-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	background: transparent;
	color: var(--z2w-primary, #4f46e5);
	border: 1.5px solid var(--z2w-primary, #4f46e5);
	border-radius: 4px;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
}

.z2w-docx-download-btn:hover,
.z2w-docx-download-btn:focus {
	background: var(--z2w-primary, #4f46e5);
	color: #fff;
	text-decoration: none;
}

.z2w-docx-hint {
	margin: 6px 0 0;
	font-size: 12px;
	color: #888;
}

.z2w-docx-login-prompt {
	margin-top: 14px;
	font-size: 13px;
	color: #555;
	text-align: center;
}
