/* public/css/dfb-public.css */
@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700&display=swap');

.dfb-form-wrapper {
	max-width: var(--dfb-max-width, 480px);
	margin: 0 auto;
	font-family: var(--dfb-font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
	box-sizing: border-box;
	background-color: var(--dfb-bg-color, #ffffff);
	padding: 40px;
	border-radius: 24px;
	box-shadow: var(--dfb-card-shadow, 0 12px 48px rgba(0, 0, 0, 0.06), 0 2px 6px rgba(0, 0, 0, 0.03));
	border: 1px solid rgba(0, 0, 0, 0.04);
	color: var(--dfb-text-color, inherit);
}

.dfb-form-wrapper[dir="rtl"] {
	font-family: var(--dfb-font-family, 'Cairo', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
}

.dfb-form-wrapper[dir="rtl"],
.dfb-form-wrapper[dir="rtl"] .dfb-label,
.dfb-form-wrapper[dir="rtl"] .dfb-message {
	text-align: right;
}

.dfb-message {
	padding: 16px;
	margin-bottom: 24px;
	border-radius: 12px;
	border: 1px solid transparent;
	font-size: 0.95rem;
	line-height: 1.5;
}

.dfb-form-heading {
	margin-bottom: 30px;
	text-align: center;
}

.dfb-form-heading .dfb-form-title {
	font-size: var(--dfb-title-size, calc(var(--dfb-font-size, 1rem) * 1.5));
	color: var(--dfb-title-color, var(--dfb-text-color, inherit));
	font-weight: 700;
	margin: 0 0 8px 0;
	line-height: 1.3;
}

.dfb-form-heading .dfb-form-subtitle {
	font-size: calc(var(--dfb-font-size, 1rem) * 0.95);
	color: var(--dfb-label-color, #6b7280);
	margin: 0;
	line-height: 1.5;
}

.dfb-success {
	color: #065f46;
	background-color: #d1fae5;
	border-color: #a7f3d0;
}

.dfb-error {
	color: #991b1b;
	background-color: #fee2e2;
	border-color: #fecaca;
}

.dfb-field-group {
	margin-bottom: var(--dfb-field-spacing, 24px);
}

.dfb-field-group.dfb-field-type-hidden {
	margin-bottom: 0;
	display: none;
}

.dfb-label {
	display: block;
	margin-bottom: 6px;
	font-weight: var(--dfb-label-weight, 600);
	color: var(--dfb-label-color, #6b7280);
	font-size: var(--dfb-label-size, var(--dfb-font-size, 0.82rem));
}

.dfb-required {
	color: #ef4444;
	margin-inline-start: 3px;
}

.dfb-input-wrapper {
	position: relative;
}

.dfb-input {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid var(--dfb-input-border, #e5e7eb);
	border-radius: var(--dfb-border-radius, 12px);
	box-sizing: border-box;
	font-family: inherit;
	font-size: calc(var(--dfb-font-size, 1rem) * 1.15);
	/* Keep inputs slightly larger than labels */
	background-color: var(--dfb-input-bg, #f9fafb);
	color: var(--dfb-text-color, #1f2937);
	transition: all 0.25s ease-in-out;
	max-width: 100%;
	height: 52px;
}

.dfb-input:focus {
	border-color: var(--dfb-primary-color, #8b5cf6);
	background-color: var(--dfb-bg-color, #ffffff);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--dfb-primary-color, #8b5cf6) 15%, transparent);
	outline: none;
}

.dfb-input::placeholder {
	color: #9ca3af;
	font-size: 0.9rem;
	/* Smaller placeholder text */
	opacity: 1;
	/* Override firefox opacity */
}

textarea.dfb-input {
	min-height: 120px;
	height: auto;
	resize: vertical;
	padding-top: 16px;
}

select.dfb-input {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
	background-size: 16px;
	padding-right: 40px;
}

.dfb-form-wrapper[dir="rtl"] select.dfb-input {
	background-position: left 16px center;
	padding-right: 16px;
	padding-left: 40px;
}

.dfb-radio-group,
.dfb-checkbox-group {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-top: 8px;
}

.dfb-radio-label,
.dfb-checkbox-label {
	display: inline-flex;
	align-items: center;
	font-weight: 400;
	color: #4b5563;
	cursor: pointer;
	font-size: 0.95rem;
}

.dfb-radio-label input,
.dfb-checkbox-label input {
	margin-inline-end: 10px;
	width: 20px;
	height: 20px;
	accent-color: var(--dfb-primary-color, #8b5cf6);
	cursor: pointer;
	flex-shrink: 0;
}

.dfb-submit-group {
	margin-top: 36px;
}

.dfb-submit-btn {
	width: 100%;
	height: 52px;
	background: var(--dfb-btn-bg-fallback, linear-gradient(135deg, var(--dfb-btn-grad-start, var(--dfb-primary-color, #6366f1)) 0%, var(--dfb-btn-grad-end, var(--dfb-primary-color, #8b5cf6)) 100%));
	color: var(--dfb-btn-text, #ffffff);
	border: none;
	border-radius: var(--dfb-border-radius, 12px);
	cursor: pointer;
	font-size: calc(var(--dfb-font-size, 1rem) * 1.15);
	font-weight: 600;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	box-shadow: 0 4px 12px color-mix(in srgb, var(--dfb-primary-color, #8b5cf6) 25%, transparent);
}

.dfb-submit-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px color-mix(in srgb, var(--dfb-primary-color, #8b5cf6) 40%, transparent);
}

.dfb-submit-btn:active {
	transform: translateY(0);
	box-shadow: 0 2px 8px color-mix(in srgb, var(--dfb-primary-color, #8b5cf6) 30%, transparent);
}

.dfb-submit-btn:disabled {
	opacity: 0.6;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

.dfb-error-msg {
	color: #ef4444;
	font-weight: 500;
	font-size: 0.85rem;
	margin-top: 6px;
}

/* ========================================================================
   STRICT LTR ENFORCEMENT FOR PHONE FIELD (MATCHES REFERENCE DESIGN EXACTLY)
   ======================================================================== */

.iti {
	width: 100%;
}

/* Force the entire phone container to LTR */
.dfb-form-wrapper[dir="rtl"] .iti {
	direction: ltr !important;
}

/* The input field itself */
.dfb-form-wrapper[dir="rtl"] .iti .dfb-input,
.iti .dfb-input {
	direction: ltr !important;
	text-align: left !important;
	/* Increased padding to add more space between +971 and the typed number */
	padding-left: 115px !important;
	padding-right: 16px !important;
	padding-top: 14px;
	padding-bottom: 14px;
}

/* Force flag container to the left side */
.dfb-form-wrapper[dir="rtl"] .iti__flag-container,
.iti__flag-container {
	left: 0 !important;
	right: auto !important;
	padding: 1px !important;
	/* Slight inset so it doesn't overlap input border */
}

/* Style the selected flag area to match the gray box design perfectly */
.dfb-form-wrapper[dir="rtl"] .iti__selected-flag,
.iti__selected-flag {
	direction: ltr !important;
	flex-direction: row !important;
	background-color: #f8f9fa !important;
	/* Slightly lighter different background */
	border-right: 1px solid #e5e7eb !important;
	border-radius: 11px 0 0 11px !important;
	padding: 0 12px 0 16px !important;
	height: 100%;
}

.dfb-form-wrapper[dir="rtl"] .iti__selected-flag:hover,
.iti__selected-flag:hover {
	background-color: #f3f4f6 !important;
}

/* Ensure dropdown anchors correctly to the left and expands naturally */
.dfb-form-wrapper[dir="rtl"] .iti__country-list,
.iti__country-list {
	direction: ltr !important;
	text-align: left !important;
	left: 0 !important;
	right: auto !important;

	/* Match the exact field size (480px max wrapper - 80px padding = 400px) */
	width: 400px !important;
	/* Ensure it shrinks cleanly on mobile devices */
	max-width: calc(100vw - 80px) !important;

	z-index: 99999 !important;
	border-radius: 8px;
	border: 1px solid #e5e7eb;
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12), 0 4px 12px rgba(0, 0, 0, 0.05);
	margin-top: 8px !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: 0.95rem;
	max-height: 250px;
	overflow-y: auto;
	overflow-x: hidden !important;
	scrollbar-width: thin;
	scrollbar-color: #cbd5e1 transparent;
	white-space: normal !important;
}

.iti__country-list::-webkit-scrollbar {
	width: 6px;
}

.iti__country-list::-webkit-scrollbar-thumb {
	background-color: #cbd5e1;
	border-radius: 10px;
}

/* Dropdown list items */
.dfb-form-wrapper[dir="rtl"] .iti__country,
.iti__country {
	direction: ltr !important;
	flex-direction: row !important;
	justify-content: flex-start !important;
	padding: 10px 16px !important;
	display: flex !important;
	align-items: center;
	transition: background-color 0.15s;
}

.dfb-form-wrapper[dir="rtl"] .iti__country:hover,
.iti__country:hover {
	background-color: #f3f4f6 !important;
}

/* Correct the margins that intl-tel-input reversed */
.dfb-form-wrapper[dir="rtl"] .iti__flag-box,
.iti__flag-box,
.dfb-form-wrapper[dir="rtl"] .iti__country-name,
.iti__country-name {
	margin-right: 8px !important;
	margin-left: 0 !important;
}

/* Guarantee +971 renders correctly using isolate */
.dfb-form-wrapper[dir="rtl"] .iti__selected-dial-code,
.dfb-form-wrapper[dir="rtl"] .iti__dial-code,
.iti__selected-dial-code,
.iti__dial-code {
	direction: ltr !important;
	unicode-bidi: isolate !important;
	display: inline-block !important;
}

/* Make the selected dial code (+971) significantly smaller, bolder, and softer in color */
.dfb-form-wrapper[dir="rtl"] .iti__selected-dial-code,
.iti__selected-dial-code {
	font-size: 0.75rem !important;
	/* Made significantly smaller */
	font-weight: 500 !important;
	color: #6b7280 !important;
	/* Softer medium gray */
}

/* Gray out the dial code in the dropdown to match the reference */
.dfb-form-wrapper[dir="rtl"] .iti__dial-code,
.iti__dial-code {
	color: #9ca3af !important;
}

/* Dropdown arrow margin */
.dfb-form-wrapper[dir="rtl"] .iti__arrow,
.iti__arrow {
	margin-left: 6px !important;
	margin-right: 0 !important;
}

.iti__flag {
	background-image: url("https://cdn.jsdelivr.net/npm/intl-tel-input@18.2.1/build/img/flags.png");
}

@media (min-resolution: 2x) {
	.iti__flag {
		background-image: url("https://cdn.jsdelivr.net/npm/intl-tel-input@18.2.1/build/img/flags@2x.png");
	}
}