/* ==========================================================================
   B24 AI Website Generator Form - Black & White, No Gradients
   High-specificity selectors to prevent theme overrides.
   ========================================================================== */


/* Reset: kill inherited theme styles inside our form */
#b24-form-wrap,
#b24-form-wrap *,
#b24-form-wrap *::before,
#b24-form-wrap *::after {
	box-sizing: border-box !important;
	text-transform: none !important;
	letter-spacing: normal;
}

#b24-form-wrap {
	position: relative;
	max-width: 640px;
	margin: 0 auto;
	padding: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
	color: #000000 !important;
	line-height: 1.5 !important;
	font-size: 14px !important;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
}

/* Progress Bar
   ========================================================================== */

#b24-form-wrap .b24-progress {
	margin-bottom: 32px;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
}

#b24-form-wrap .b24-progress-track {
	width: 100%;
	height: 3px;
	background: #E0E0E0 !important;
	margin-bottom: 16px;
	border: none !important;
	border-radius: 0 !important;
}

#b24-form-wrap .b24-progress-fill {
	height: 100%;
	background: #000000 !important;
	transition: width 0.4s ease;
	border-radius: 0 !important;
}

#b24-form-wrap .b24-steps-indicator {
	display: flex !important;
	justify-content: space-between;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

#b24-form-wrap .b24-step-dot {
	display: flex !important;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	cursor: default;
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

#b24-form-wrap .b24-step-num {
	width: 32px;
	height: 32px;
	min-width: 32px;
	border-radius: 50% !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	font-size: 13px !important;
	font-weight: 600 !important;
	border: 2px solid #E0E0E0 !important;
	color: #888888 !important;
	background: #FFFFFF !important;
	transition: all 0.3s ease;
	padding: 0 !important;
	margin: 0 !important;
	line-height: 1 !important;
}

#b24-form-wrap .b24-step-dot.active .b24-step-num {
	background: #000000 !important;
	color: #FFFFFF !important;
	border-color: #000000 !important;
}

#b24-form-wrap .b24-step-dot.completed .b24-step-num {
	background: #000000 !important;
	color: #FFFFFF !important;
	border-color: #000000 !important;
}

#b24-form-wrap .b24-step-dot.completed .b24-step-num::after {
	content: "\2713";
}

#b24-form-wrap .b24-step-dot.completed .b24-step-num span {
	display: none !important;
}

#b24-form-wrap .b24-step-label {
	font-size: 11px !important;
	font-weight: 500 !important;
	color: #888888 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.5px !important;
	line-height: 1.2 !important;
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

#b24-form-wrap .b24-step-dot.active .b24-step-label,
#b24-form-wrap .b24-step-dot.completed .b24-step-label {
	color: #000000 !important;
}

/* Steps
   ========================================================================== */

#b24-form-wrap .b24-step {
	animation: b24FadeIn 0.3s ease;
}

@keyframes b24FadeIn {
	from { opacity: 0; transform: translateX(20px); }
	to   { opacity: 1; transform: translateX(0); }
}

#b24-form-wrap .b24-step-title {
	margin: 0 0 4px !important;
	padding: 0 !important;
	font-size: 22px !important;
	font-weight: 600 !important;
	color: #000000 !important;
	background: transparent !important;
	border: none !important;
	line-height: 1.3 !important;
	text-align: left !important;
}

#b24-form-wrap .b24-step-desc {
	margin: 0 0 28px !important;
	padding: 0 !important;
	font-size: 14px !important;
	color: #888888 !important;
	line-height: 1.5 !important;
	text-align: left !important;
}

/* Form Fields
   ========================================================================== */

#b24-form-wrap .b24-field {
	margin-bottom: 20px;
}

#b24-form-wrap .b24-field > label {
	display: block !important;
	margin-bottom: 6px !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: #000000 !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
	line-height: 1.4 !important;
	text-align: left !important;
	float: none !important;
	width: auto !important;
}

#b24-form-wrap .b24-req {
	color: #DC2626 !important;
}

#b24-form-wrap .b24-field input[type="text"],
#b24-form-wrap .b24-field input[type="email"],
#b24-form-wrap .b24-field input[type="tel"],
#b24-form-wrap .b24-field textarea,
#b24-form-wrap .b24-field select,
#b24-form-wrap .b24-select-search {
	width: 100% !important;
	padding: 10px 12px !important;
	font-size: 14px !important;
	font-family: inherit !important;
	color: #000000 !important;
	background: #FFFFFF !important;
	border: 1px solid #E0E0E0 !important;
	border-radius: 4px !important;
	outline: none !important;
	transition: border-color 0.2s ease;
	-webkit-appearance: none !important;
	appearance: none !important;
	box-shadow: none !important;
	margin: 0 !important;
	height: auto !important;
	min-height: 0 !important;
	line-height: 1.4 !important;
	float: none !important;
}

#b24-form-wrap .b24-field input[type="text"]:focus,
#b24-form-wrap .b24-field input[type="email"]:focus,
#b24-form-wrap .b24-field input[type="tel"]:focus,
#b24-form-wrap .b24-field textarea:focus,
#b24-form-wrap .b24-field select:focus,
#b24-form-wrap .b24-select-search:focus {
	border-color: #000000 !important;
	box-shadow: none !important;
	outline: none !important;
}

#b24-form-wrap .b24-field input::placeholder,
#b24-form-wrap .b24-field textarea::placeholder,
#b24-form-wrap .b24-select-search::placeholder {
	color: #AAAAAA !important;
	opacity: 1 !important;
}

#b24-form-wrap .b24-field textarea {
	resize: vertical;
	min-height: 60px;
}

#b24-form-wrap .b24-field select {
	background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23000' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: right 12px center !important;
	padding-right: 32px !important;
	cursor: pointer;
}

#b24-form-wrap .b24-field.b24-field-error input,
#b24-form-wrap .b24-field.b24-field-error textarea,
#b24-form-wrap .b24-field.b24-field-error select,
#b24-form-wrap .b24-field.b24-field-error .b24-select-search {
	border-color: #DC2626 !important;
}

#b24-form-wrap .b24-error {
	display: none;
	font-size: 12px !important;
	color: #DC2626 !important;
	margin-top: 4px !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
}

#b24-form-wrap .b24-field.b24-field-error .b24-error {
	display: block !important;
}

/* Searchable Select (Business Type)
   ========================================================================== */

#b24-form-wrap .b24-select-wrap {
	position: relative;
}

#b24-form-wrap .b24-select-dropdown {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	max-height: 200px;
	overflow-y: auto;
	background: #FFFFFF !important;
	border: 1px solid #000000 !important;
	border-top: none !important;
	border-radius: 0 0 4px 4px !important;
	z-index: 100;
	box-shadow: none !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

#b24-form-wrap .b24-select-dropdown.open {
	display: block !important;
}

#b24-form-wrap .b24-select-option {
	padding: 8px 12px !important;
	font-size: 14px !important;
	cursor: pointer;
	transition: background-color 0.15s ease;
	color: #000000 !important;
	background: #FFFFFF !important;
	border: none !important;
	margin: 0 !important;
	list-style: none !important;
	display: block !important;
	line-height: 1.4 !important;
	text-align: left !important;
}

#b24-form-wrap .b24-select-option:hover,
#b24-form-wrap .b24-select-option.highlighted {
	background: #000000 !important;
	color: #FFFFFF !important;
}

#b24-form-wrap .b24-select-option.selected {
	font-weight: 600 !important;
}

#b24-form-wrap .b24-select-option.hidden {
	display: none !important;
}

/* Color Pickers
   ========================================================================== */

#b24-form-wrap .b24-color-grid {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-bottom: 20px;
}

#b24-form-wrap .b24-field-color > label {
	margin-bottom: 8px !important;
}

#b24-form-wrap .b24-color-input-wrap {
	display: flex !important;
	align-items: center;
	gap: 8px;
	border: 1px solid #E0E0E0 !important;
	border-radius: 4px !important;
	padding: 4px !important;
	background: #FFFFFF !important;
}

#b24-form-wrap .b24-color-input-wrap input[type="color"] {
	width: 36px !important;
	height: 36px !important;
	border: none !important;
	padding: 0 !important;
	cursor: pointer;
	border-radius: 2px !important;
	background: none !important;
	box-shadow: none !important;
}

#b24-form-wrap .b24-color-input-wrap input[type="color"]::-webkit-color-swatch-wrapper {
	padding: 0;
}

#b24-form-wrap .b24-color-input-wrap input[type="color"]::-webkit-color-swatch {
	border: 1px solid #E0E0E0;
	border-radius: 2px;
}

#b24-form-wrap .b24-color-hex {
	flex: 1;
	border: none !important;
	padding: 6px 4px !important;
	font-size: 13px !important;
	font-family: monospace !important;
	text-transform: uppercase !important;
	min-width: 0;
	background: transparent !important;
	box-shadow: none !important;
}

#b24-form-wrap .b24-color-hex:focus {
	border: none !important;
	box-shadow: none !important;
}

/* Checkboxes (Pages)
   ========================================================================== */

#b24-form-wrap .b24-checkbox-grid {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr);
	gap: 8px;
}

#b24-form-wrap label.b24-checkbox {
	display: flex !important;
	align-items: center !important;
	gap: 8px;
	padding: 8px 12px !important;
	border: 1px solid #E0E0E0 !important;
	border-radius: 4px !important;
	cursor: pointer;
	font-size: 14px !important;
	font-weight: 400 !important;
	transition: border-color 0.2s ease;
	background: #FFFFFF !important;
	margin: 0 !important;
	line-height: 1.4 !important;
	color: #000000 !important;
	float: none !important;
	width: auto !important;
}

#b24-form-wrap label.b24-checkbox:hover {
	border-color: #000000 !important;
}

#b24-form-wrap .b24-checkbox input[type="checkbox"] {
	width: 16px !important;
	height: 16px !important;
	accent-color: #000000;
	cursor: pointer;
	margin: 0 !important;
	padding: 0 !important;
	-webkit-appearance: auto !important;
	appearance: auto !important;
	border: none !important;
	box-shadow: none !important;
}

#b24-form-wrap .b24-checkbox input[type="checkbox"]:disabled {
	opacity: 0.5;
}

#b24-form-wrap .b24-checkbox input[type="checkbox"]:checked + span {
	font-weight: 500 !important;
}

#b24-form-wrap .b24-checkbox span {
	font-size: 14px !important;
	color: #000000 !important;
}

/* Review Step
   ========================================================================== */

#b24-form-wrap .b24-review-section {
	border: 1px solid #E0E0E0 !important;
	border-radius: 4px !important;
	margin-bottom: 16px;
	background: #FFFFFF !important;
	box-shadow: none !important;
	padding: 0 !important;
}

#b24-form-wrap .b24-review-header {
	display: flex !important;
	justify-content: space-between;
	align-items: center;
	padding: 12px 16px !important;
	border-bottom: 1px solid #E0E0E0 !important;
	background: transparent !important;
	margin: 0 !important;
}

#b24-form-wrap .b24-review-header h3 {
	margin: 0 !important;
	padding: 0 !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	color: #000000 !important;
	background: transparent !important;
	border: none !important;
	line-height: 1.3 !important;
	text-align: left !important;
}

#b24-form-wrap .b24-edit-btn {
	background: none !important;
	border: 1px solid #E0E0E0 !important;
	padding: 4px 12px !important;
	font-size: 12px !important;
	cursor: pointer;
	border-radius: 4px !important;
	color: #000000 !important;
	font-weight: 500 !important;
	transition: border-color 0.2s ease;
	box-shadow: none !important;
	line-height: 1.4 !important;
	margin: 0 !important;
}

#b24-form-wrap .b24-edit-btn:hover {
	border-color: #000000 !important;
}

#b24-form-wrap .b24-review-grid {
	display: grid !important;
	grid-template-columns: 1fr 1fr;
	gap: 0;
}

#b24-form-wrap .b24-review-item {
	padding: 10px 16px !important;
	border-bottom: 1px solid #F0F0F0 !important;
	background: transparent !important;
	margin: 0 !important;
}

#b24-form-wrap .b24-review-item.b24-review-full {
	grid-column: 1 / -1;
}

#b24-form-wrap .b24-review-label {
	display: block !important;
	font-size: 11px !important;
	font-weight: 500 !important;
	color: #888888 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.5px !important;
	margin-bottom: 2px !important;
	padding: 0 !important;
	line-height: 1.3 !important;
}

#b24-form-wrap .b24-review-value {
	display: block !important;
	font-size: 14px !important;
	color: #000000 !important;
	word-break: break-word;
	line-height: 1.4 !important;
	padding: 0 !important;
	margin: 0 !important;
}

#b24-form-wrap .b24-color-swatch {
	display: inline-block !important;
	width: 16px;
	height: 16px;
	border-radius: 2px !important;
	border: 1px solid #E0E0E0 !important;
	vertical-align: middle;
	margin-right: 4px;
}

/* Navigation
   ========================================================================== */

#b24-form-wrap .b24-nav {
	display: flex !important;
	justify-content: space-between;
	align-items: center;
	margin-top: 32px;
	padding-top: 24px;
	border-top: 1px solid #E0E0E0 !important;
	background: transparent !important;
}

#b24-form-wrap .b24-nav-spacer {
	flex: 1;
}

#b24-form-wrap .b24-btn {
	padding: 10px 28px !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	border-radius: 4px !important;
	cursor: pointer;
	transition: opacity 0.2s ease;
	line-height: 1.4 !important;
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	box-shadow: none !important;
	outline: none !important;
	display: inline-block !important;
	text-align: center !important;
	vertical-align: middle !important;
	float: none !important;
	margin: 0 !important;
	min-height: 0 !important;
	height: auto !important;
}

#b24-form-wrap .b24-btn:hover {
	opacity: 0.85;
}

#b24-form-wrap .b24-btn:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

#b24-form-wrap .b24-btn-primary {
	background: #000000 !important;
	color: #FFFFFF !important;
	border: 1px solid #000000 !important;
}

#b24-form-wrap .b24-btn-secondary {
	background: #FFFFFF !important;
	color: #000000 !important;
	border: 1px solid #000000 !important;
}

/* Success State
   ========================================================================== */

#b24-form-wrap .b24-success {
	text-align: center !important;
	padding: 48px 24px !important;
}

#b24-form-wrap .b24-success-icon {
	width: 56px;
	height: 56px;
	border-radius: 50% !important;
	background: #000000 !important;
	color: #FFFFFF !important;
	font-size: 28px !important;
	line-height: 56px !important;
	margin: 0 auto 20px !important;
	display: block !important;
	text-align: center !important;
}

#b24-form-wrap .b24-success h2 {
	margin: 0 0 12px !important;
	padding: 0 !important;
	font-size: 22px !important;
	font-weight: 600 !important;
	color: #000000 !important;
	line-height: 1.3 !important;
	background: transparent !important;
	border: none !important;
}

#b24-form-wrap .b24-success p {
	margin: 0 0 8px !important;
	font-size: 15px !important;
	color: #444444 !important;
	line-height: 1.6 !important;
	padding: 0 !important;
}

#b24-form-wrap .b24-success-note {
	font-size: 13px !important;
	color: #888888 !important;
}

#b24-form-wrap .b24-success a {
	color: #000000 !important;
	font-weight: 600 !important;
}

/* Error State
   ========================================================================== */

#b24-form-wrap .b24-form-error {
	background: #FEF2F2 !important;
	border: 1px solid #DC2626 !important;
	border-radius: 4px !important;
	padding: 12px 16px !important;
	margin-top: 16px;
	box-shadow: none !important;
}

#b24-form-wrap .b24-form-error p {
	margin: 0 !important;
	color: #DC2626 !important;
	font-size: 14px !important;
	padding: 0 !important;
}

/* Loading Overlay
   ========================================================================== */

#b24-form-wrap .b24-loading {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(255, 255, 255, 0.95) !important;
	display: flex !important;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	z-index: 200;
}

#b24-form-wrap .b24-spinner {
	width: 40px;
	height: 40px;
	border: 3px solid #E0E0E0 !important;
	border-top-color: #000000 !important;
	border-radius: 50% !important;
	animation: b24Spin 0.8s linear infinite;
	margin-bottom: 16px;
	background: transparent !important;
}

@keyframes b24Spin {
	to { transform: rotate(360deg); }
}

#b24-form-wrap .b24-loading p {
	margin: 0 !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	color: #000000 !important;
	text-align: center !important;
	padding: 0 !important;
}

#b24-form-wrap .b24-loading-sub {
	font-size: 13px !important;
	font-weight: 400 !important;
	color: #888888 !important;
}

/* Responsive
   ========================================================================== */

@media (max-width: 640px) {
	#b24-form-wrap {
		padding: 0 16px;
	}

	#b24-form-wrap .b24-color-grid {
		grid-template-columns: 1fr !important;
	}

	#b24-form-wrap .b24-checkbox-grid {
		grid-template-columns: 1fr !important;
	}

	#b24-form-wrap .b24-review-grid {
		grid-template-columns: 1fr !important;
	}

	#b24-form-wrap .b24-step-label {
		display: none !important;
	}

	#b24-form-wrap .b24-steps-indicator {
		justify-content: center;
		gap: 24px;
	}
}

/* ==========================================================================
   Utility: MUST be last rule so it wins over all !important display rules
   by source order. Uses ID + doubled class for maximum specificity.
   ========================================================================== */
#b24-form-wrap .b24-hidden.b24-hidden {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	overflow: hidden !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
}
